mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-09 18:20:59 +01:00
- FIX: grep -a if we hit binary content with http_header (also if otherwise specified)
- NEW: can specify URL (used for header matters and breach) - FIX: better handling of >1 cookies
This commit is contained in:
parent
549d523728
commit
4c72e059b8
88
testssl.sh
88
testssl.sh
@ -265,7 +265,8 @@ wait_kill(){
|
|||||||
# foreign referers are the important thing here!
|
# foreign referers are the important thing here!
|
||||||
breach() {
|
breach() {
|
||||||
bold " BREACH"; out " =HTTP Compression, experimental "
|
bold " BREACH"; out " =HTTP Compression, experimental "
|
||||||
[ -z "$1" ] && url="/"
|
url="$1"
|
||||||
|
[ -z "$url" ] && url="/"
|
||||||
if [ $SNEAKY -eq 0 ] ; then
|
if [ $SNEAKY -eq 0 ] ; then
|
||||||
referer="Referer: http://google.com/" # see https://community.qualys.com/message/20360
|
referer="Referer: http://google.com/" # see https://community.qualys.com/message/20360
|
||||||
useragent="User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)"
|
useragent="User-Agent: Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)"
|
||||||
@ -380,9 +381,9 @@ EOF
|
|||||||
ret=0
|
ret=0
|
||||||
else
|
else
|
||||||
magenta " header request stalled"
|
magenta " header request stalled"
|
||||||
egrep -wq "301|302|^Location" $HEADERFILE
|
egrep -awq "301|302|^Location" $HEADERFILE
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
redir2=`grep '^Location' $HEADERFILE | sed 's/Location: //' | tr -d '\r\n'`
|
redir2=`grep -a '^Location' $HEADERFILE | sed 's/Location: //' | tr -d '\r\n'`
|
||||||
outln " (30x to $redir2, tried this URL?)"
|
outln " (30x to $redir2, tried this URL?)"
|
||||||
fi
|
fi
|
||||||
[[ $DEBUG -eq 0 ]] && rm $HEADERFILE.2 $HEADERFILE 2>/dev/null
|
[[ $DEBUG -eq 0 ]] && rm $HEADERFILE.2 $HEADERFILE 2>/dev/null
|
||||||
@ -392,22 +393,21 @@ EOF
|
|||||||
}
|
}
|
||||||
|
|
||||||
includeSubDomains() {
|
includeSubDomains() {
|
||||||
if grep -q includeSubDomains "$1"; then
|
if grep -aiq includeSubDomains "$1"; then
|
||||||
litegreen ", includeSubDomains"
|
litegreen ", includeSubDomains"
|
||||||
else
|
else
|
||||||
litecyan ", just this domain"
|
litecyan ", just this domain"
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
#FIXME: it doesn't follow a 30x. At least a path should be possible to provide
|
|
||||||
hsts() {
|
hsts() {
|
||||||
bold " HSTS "
|
bold " HSTS "
|
||||||
if [ ! -s $HEADERFILE ] ; then
|
if [ ! -s $HEADERFILE ] ; then
|
||||||
http_header || return 3
|
http_header "$1" || return 3
|
||||||
fi
|
fi
|
||||||
grep -iw '^Strict-Transport-Security' $HEADERFILE >$TMPFILE
|
grep -iaw '^Strict-Transport-Security' $HEADERFILE >$TMPFILE
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
grep -ciw '^Strict-Transport-Security' $HEADERFILE | egrep -wq "1" || out "(two HSTS header, using 1st one) "
|
grep -aciw '^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
|
||||||
@ -428,11 +428,11 @@ hsts() {
|
|||||||
hpkp() {
|
hpkp() {
|
||||||
bold " HPKP "
|
bold " HPKP "
|
||||||
if [ ! -s $HEADERFILE ] ; then
|
if [ ! -s $HEADERFILE ] ; then
|
||||||
http_header || return 3
|
http_header "$1" || return 3
|
||||||
fi
|
fi
|
||||||
egrep -iw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE >$TMPFILE
|
egrep -aiw '^Public-Key-Pins|Public-Key-Pins-Report-Only' $HEADERFILE >$TMPFILE
|
||||||
if [ $? -eq 0 ]; then
|
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) "
|
egrep -aciw '^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_SEC=`sed -e 's/\r//g' -e 's/^.*max-age=//' -e 's/;.*//' $TMPFILE`
|
||||||
AGE_DAYS=`expr $AGE_SEC \/ 86400`
|
AGE_DAYS=`expr $AGE_SEC \/ 86400`
|
||||||
if [ $AGE_DAYS -ge $HPKP_MIN ]; then
|
if [ $AGE_DAYS -ge $HPKP_MIN ]; then
|
||||||
@ -450,15 +450,14 @@ hpkp() {
|
|||||||
tmpfile_handle $FUNCNAME.txt
|
tmpfile_handle $FUNCNAME.txt
|
||||||
return $?
|
return $?
|
||||||
}
|
}
|
||||||
#FIXME: report-uri
|
|
||||||
#FIXME: once checkcert.sh is here: fingerprints!
|
#FIXME: once checkcert.sh is here: fingerprints!
|
||||||
|
|
||||||
serverbanner() {
|
serverbanner() {
|
||||||
bold " Server "
|
bold " Server "
|
||||||
if [ ! -s $HEADERFILE ] ; then
|
if [ ! -s $HEADERFILE ] ; then
|
||||||
http_header || return 3
|
http_header "$1" || return 3
|
||||||
fi
|
fi
|
||||||
grep -i '^Server' $HEADERFILE >$TMPFILE
|
grep -ai '^Server' $HEADERFILE >$TMPFILE
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
#out=`cat $TMPFILE | sed -e 's/^Server: //' -e 's/^server: //' -e 's/^[[:space:]]//'`
|
#out=`cat $TMPFILE | sed -e 's/^Server: //' -e 's/^server: //' -e 's/^[[:space:]]//'`
|
||||||
serverbanner=`cat $TMPFILE | sed -e 's/^Server: //' -e 's/^server: //'`
|
serverbanner=`cat $TMPFILE | sed -e 's/^Server: //' -e 's/^server: //'`
|
||||||
@ -472,8 +471,8 @@ serverbanner() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
bold " Application "
|
bold " Application "
|
||||||
# examples: php.net, asp.net , www.regonline.com
|
# examples: dev.testssl.sh, php.net, asp.net , www.regonline.com
|
||||||
egrep -i '^X-Powered-By|^X-AspNet-Version|^X-Runtime|^X-Version' $HEADERFILE >$TMPFILE
|
egrep -ai '^X-Powered-By|^X-AspNet-Version|^X-Runtime|^X-Version' $HEADERFILE >$TMPFILE
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
#cat $TMPFILE | sed 's/^.*:/:/' | sed -e :a -e '$!N;s/\n:/ \n\ +/;ta' -e 'P;D' | sed 's/://g'
|
#cat $TMPFILE | sed 's/^.*:/:/' | sed -e :a -e '$!N;s/\n:/ \n\ +/;ta' -e 'P;D' | sed 's/://g'
|
||||||
sed 's/^/ /g' $TMPFILE | tr -t '\n\r' ' '
|
sed 's/^/ /g' $TMPFILE | tr -t '\n\r' ' '
|
||||||
@ -494,29 +493,33 @@ serverbanner() {
|
|||||||
return $?
|
return $?
|
||||||
}
|
}
|
||||||
|
|
||||||
#dead function as of now
|
|
||||||
cookieflags() { # ARG1: Path, ARG2: path
|
cookieflags() { # ARG1: Path, ARG2: path
|
||||||
bold " Cookie(s) "
|
bold " Cookie(s) "
|
||||||
if [ ! -s $HEADERFILE ] ; then
|
if [ ! -s $HEADERFILE ] ; then
|
||||||
http_header "$1" || return 3
|
http_header "$1" || return 3
|
||||||
fi
|
fi
|
||||||
grep -i '^Set-Cookie' $HEADERFILE >$TMPFILE
|
grep -ai '^Set-Cookie' $HEADERFILE >$TMPFILE
|
||||||
# lines!
|
|
||||||
if [ $? -eq 0 ]; then
|
if [ $? -eq 0 ]; then
|
||||||
out $(wc -l $TMPFILE)
|
nr_cookies=`cat $TMPFILE | wc -l`
|
||||||
out ": "
|
if [ $nr_cookies -gt 1 ] ; then
|
||||||
if grep -q -i secure $TMPFILE; then
|
out $(wc -l $TMPFILE)
|
||||||
litegreen "Secure, "
|
out " issued: "
|
||||||
|
negative_word="NOONE"
|
||||||
else
|
else
|
||||||
out "NOT secure, "
|
negative_word="NOT"
|
||||||
fi
|
|
||||||
if grep -q -i httponly $TMPFILE; then
|
|
||||||
litegreen "HttpOnly "
|
|
||||||
else
|
|
||||||
out "NOT HttpOnly"
|
|
||||||
fi
|
fi
|
||||||
|
nr_secure=`grep -iac secure $TMPFILE`
|
||||||
|
case $nr_secure in
|
||||||
|
0) out "$negative_word secure, " ;;
|
||||||
|
[123456789]) litegreen "$nr_secure/$nr_cookies secure" ; out ", ";;
|
||||||
|
esac
|
||||||
|
nr_httponly=`grep -cai httponly $TMPFILE`
|
||||||
|
case $nr_httponly in
|
||||||
|
0) out "$negative_word HttpOnly" ;;
|
||||||
|
[123456789]) litegreen "$nr_secure/$nr_cookies HttpOnly" ;;
|
||||||
|
esac
|
||||||
else
|
else
|
||||||
out "none issued"
|
out "none issued at \"$url\""
|
||||||
fi
|
fi
|
||||||
outln
|
outln
|
||||||
|
|
||||||
@ -1973,8 +1976,8 @@ parse_hn_port() {
|
|||||||
fi
|
fi
|
||||||
SNI="-servername $NODE"
|
SNI="-servername $NODE"
|
||||||
|
|
||||||
#URLP=`echo $1 | sed 's/'"${PROTO}"':\/\/'"${NODE}"'//'`
|
URL_PATH=`echo $1 | sed 's/.*'"${NODE}"'//'` # remove protocol and node part
|
||||||
#URLP=`echo $URLP | sed 's/\/\//\//g'` # // -> /
|
URL_PATH=`echo $URL_PATH | sed 's/\/\//\//g'` # we rather want // -> /
|
||||||
|
|
||||||
# now get NODEIP
|
# now get NODEIP
|
||||||
get_dns_entries
|
get_dns_entries
|
||||||
@ -2202,7 +2205,7 @@ case "$1" in
|
|||||||
litemagentaln " Wrong usage: You're not targetting a HTTP service"
|
litemagentaln " Wrong usage: You're not targetting a HTTP service"
|
||||||
ret=2
|
ret=2
|
||||||
else
|
else
|
||||||
breach
|
breach "$URL_PATH"
|
||||||
ret=$?
|
ret=$?
|
||||||
fi
|
fi
|
||||||
ret=`expr $? + $ret`
|
ret=`expr $? + $ret`
|
||||||
@ -2232,12 +2235,12 @@ case "$1" in
|
|||||||
parse_hn_port "$2"
|
parse_hn_port "$2"
|
||||||
outln; blue "--> Testing HTTP Header response"; outln "\n"
|
outln; blue "--> Testing HTTP Header response"; outln "\n"
|
||||||
if [[ $SERVICE == "HTTP" ]]; then
|
if [[ $SERVICE == "HTTP" ]]; then
|
||||||
hsts
|
hsts "$URL_PATH"
|
||||||
hpkp
|
hpkp "$URL_PATH"
|
||||||
ret=$?
|
ret=$?
|
||||||
serverbanner
|
serverbanner "$URL_PATH"
|
||||||
ret=`expr $? + $ret`
|
ret=`expr $? + $ret`
|
||||||
cookieflags
|
cookieflags "$URL_PATH"
|
||||||
ret=`expr $? + $ret`
|
ret=`expr $? + $ret`
|
||||||
else
|
else
|
||||||
litemagentaln " Wrong usage: You're not targetting a HTTP service"
|
litemagentaln " Wrong usage: You're not targetting a HTTP service"
|
||||||
@ -2262,16 +2265,17 @@ case "$1" in
|
|||||||
ccs_injection ; ret=`expr $? + $ret`
|
ccs_injection ; ret=`expr $? + $ret`
|
||||||
renego ; ret=`expr $? + $ret`
|
renego ; ret=`expr $? + $ret`
|
||||||
crime ; ret=`expr $? + $ret`
|
crime ; ret=`expr $? + $ret`
|
||||||
[[ $SERVICE == "HTTP" ]] && breach ; ret=`expr $? + $ret`
|
[[ $SERVICE == "HTTP" ]] && breach "$URL_PATH" ; ret=`expr $? + $ret`
|
||||||
beast ; ret=`expr $? + $ret`
|
beast ; ret=`expr $? + $ret`
|
||||||
poodle ; ret=`expr $? + $ret`
|
poodle ; ret=`expr $? + $ret`
|
||||||
|
|
||||||
if [[ $SERVICE == "HTTP" ]]; then
|
if [[ $SERVICE == "HTTP" ]]; then
|
||||||
outln; blue "--> Testing HTTP Header response"
|
outln; blue "--> Testing HTTP Header response"
|
||||||
outln "\n"
|
outln "\n"
|
||||||
hsts ; ret=`expr $? + $ret`
|
hsts $URL_PATH" ; ret=`expr $? + $ret`
|
||||||
hpkp ; ret=`expr $? + $ret`
|
hpkp $URL_PATH" ; ret=`expr $? + $ret`
|
||||||
serverbanner ; ret=`expr $? + $ret`
|
serverbanner $URL_PATH" ; ret=`expr $? + $ret`
|
||||||
|
cookieflags $URL_PATH" ; ret=`expr $? + $ret`
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rc4 ; ret=`expr $? + $ret`
|
rc4 ; ret=`expr $? + $ret`
|
||||||
@ -2279,6 +2283,6 @@ case "$1" in
|
|||||||
exit $ret ;;
|
exit $ret ;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# $Id: testssl.sh,v 1.165 2015/01/14 08:48:02 dirkw Exp $
|
# $Id: testssl.sh,v 1.166 2015/01/14 11:23:52 dirkw Exp $
|
||||||
# vim:ts=5:sw=5
|
# vim:ts=5:sw=5
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user