mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-16 13:40:58 +01:00
* protocol checks work now!
* generic jabber support now! * jabber domain support
This commit is contained in:
parent
d1442d8ca9
commit
fef9afe288
@ -8,6 +8,8 @@
|
|||||||
# mainly adapted from the C code from https://gist.github.com/rcvalle/71f4b027d61a78c42607
|
# mainly adapted from the C code from https://gist.github.com/rcvalle/71f4b027d61a78c42607
|
||||||
# thx Ramon de C Valle
|
# thx Ramon de C Valle
|
||||||
#
|
#
|
||||||
|
# handshakes from RFCs. Good source too: https://github.com/ioerror/sslscan/blob/master/sslscan.c
|
||||||
|
#
|
||||||
###### DON'T DO EVIL! USAGE AT YOUR OWN RISK. DON'T VIOLATE LAWS! #######
|
###### DON'T DO EVIL! USAGE AT YOUR OWN RISK. DON'T VIOLATE LAWS! #######
|
||||||
|
|
||||||
readonly PS4='${LINENO}: ${FUNCNAME[0]:+${FUNCNAME[0]}(): }'
|
readonly PS4='${LINENO}: ${FUNCNAME[0]:+${FUNCNAME[0]}(): }'
|
||||||
@ -17,6 +19,7 @@ trap "cleanup" QUIT EXIT
|
|||||||
|
|
||||||
NODE="$1"
|
NODE="$1"
|
||||||
PORT="443"
|
PORT="443"
|
||||||
|
JABBERNODE=${JABBERNODE}
|
||||||
SLEEP=2
|
SLEEP=2
|
||||||
MAXSLEEP=10
|
MAXSLEEP=10
|
||||||
OCKREPLY=""
|
OCKREPLY=""
|
||||||
@ -115,6 +118,11 @@ parse_hn_port() {
|
|||||||
echo -e "\n===> connecting to $NODE:$PORT\n"
|
echo -e "\n===> connecting to $NODE:$PORT\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
debugme() {
|
||||||
|
[[ $DEBUG -ge 2 ]] && "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
wait_kill(){
|
wait_kill(){
|
||||||
pid=$1
|
pid=$1
|
||||||
maxsleep=$2
|
maxsleep=$2
|
||||||
@ -132,6 +140,13 @@ wait_kill(){
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
starttls_just_read(){
|
||||||
|
echo "=== just read banner ==="
|
||||||
|
cat <&5 &
|
||||||
|
wait_kill $! $SLEEP
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
socksend() {
|
socksend() {
|
||||||
data=`echo $1`
|
data=`echo $1`
|
||||||
echo "\"$data\""
|
echo "\"$data\""
|
||||||
@ -154,12 +169,41 @@ sockread() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
# arg1: string to send
|
# arg1: string to send
|
||||||
# arg2: success string, yet to be parsed
|
# arg2: possible success strings a egrep pattern, needed!
|
||||||
starttls_line0() {
|
starttls_line0() {
|
||||||
echo "$1" >&5
|
reply=$(mktemp /tmp/reply.XXXXXX) || return 7
|
||||||
cat <&5 &
|
|
||||||
|
debugme echo -e "\n=== sending \"$1\" ..."
|
||||||
|
echo -e "$1" >&5
|
||||||
|
dd bs=1024 of=$reply count=32 <&5 2>/dev/null &
|
||||||
wait_kill $! $SLEEP
|
wait_kill $! $SLEEP
|
||||||
#[ $? -eq 3 ] && fixme "STARTTLS timed out" && exit 1
|
debugme echo "... received result: "
|
||||||
|
cat $reply
|
||||||
|
if [ -n "$2" ]; then
|
||||||
|
if egrep -q "$2" $reply; then
|
||||||
|
debugme echo "---> reply matched \"$2\""
|
||||||
|
[ $DEBUG -eq 0 ] && rm $reply
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
debugme echo "---> reply didn't match \"$2\", see $reply"
|
||||||
|
fixme "STARTTLS handshake problem"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
starttls_line1() {
|
||||||
|
echo "$1" >&5
|
||||||
|
while true; do
|
||||||
|
read line <&5
|
||||||
|
echo $line
|
||||||
|
break
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
fixme(){
|
||||||
|
tput bold; tput setaf 5; echo -e "\n$1\n"; tput sgr0
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -171,6 +215,8 @@ ok_ids() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fd_socket(){
|
fd_socket(){
|
||||||
|
local jabber=""
|
||||||
|
|
||||||
if ! exec 5<> /dev/tcp/$NODE/$PORT; then
|
if ! exec 5<> /dev/tcp/$NODE/$PORT; then
|
||||||
echo "`basename $0`: unable to connect to $NODE:$PORT"
|
echo "`basename $0`: unable to connect to $NODE:$PORT"
|
||||||
exit 2
|
exit 2
|
||||||
@ -178,42 +224,66 @@ fd_socket(){
|
|||||||
|
|
||||||
case "$1" in # port
|
case "$1" in # port
|
||||||
21) # https://tools.ietf.org/html/rfc4217
|
21) # https://tools.ietf.org/html/rfc4217
|
||||||
starttls_line0 "FEAT"
|
starttls_just_read
|
||||||
starttls_line0 "AUTH TLS"
|
starttls_line0 "FEAT" "211"
|
||||||
|
#starttls_line0 HELP "214"
|
||||||
|
starttls_line0 "AUTH TLS" "successful|234"
|
||||||
;;
|
;;
|
||||||
25) #https://tools.ietf.org/html/rfc4217
|
25) # SMTP, see https://tools.ietf.org/html/rfc4217
|
||||||
starttls_line0 "EHLO testssl.sh" "250"
|
starttls_just_read
|
||||||
|
starttls_line0 "EHLO testssl.sh" "220|250"
|
||||||
starttls_line0 "STARTTLS" "220"
|
starttls_line0 "STARTTLS" "220"
|
||||||
;;
|
;;
|
||||||
110) # https://tools.ietf.org/html/rfc2595
|
110) # POP, see https://tools.ietf.org/html/rfc2595
|
||||||
|
starttls_just_read
|
||||||
starttls_line0 "STLS" "OK"
|
starttls_line0 "STLS" "OK"
|
||||||
;;
|
;;
|
||||||
119|433) # https://tools.ietf.org/html/rfc4642
|
119|433) # NNTP, see https://tools.ietf.org/html/rfc4642
|
||||||
starttls_line0 "CAPABILITIES" "101"
|
starttls_just_read
|
||||||
|
starttls_line0 "CAPABILITIES" "101|200"
|
||||||
starttls_line0 "STARTTLS" "382"
|
starttls_line0 "STARTTLS" "382"
|
||||||
;;
|
;;
|
||||||
143) # https://tools.ietf.org/html/rfc2595
|
143) # IMAP, https://tools.ietf.org/html/rfc2595
|
||||||
|
starttls_just_read
|
||||||
starttls_line0 "a001 CAPABILITY" "OK"
|
starttls_line0 "a001 CAPABILITY" "OK"
|
||||||
starttls_line0 "a002 STARTTLS" "OK"
|
starttls_line0 "a002 STARTTLS" "OK"
|
||||||
;;
|
;;
|
||||||
389) # https://tools.ietf.org/html/rfc2830, https://tools.ietf.org/html/rfc4511
|
389) # LDAP, https://tools.ietf.org/html/rfc2830, https://tools.ietf.org/html/rfc4511
|
||||||
fixme "LDAP: FIXME not yet implemented"
|
fixme "LDAP: FIXME not yet implemented"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
674) # https://tools.ietf.org/html/rfc2595
|
674) # ACAP = Application Configuration Access Protocol, see https://tools.ietf.org/html/rfc2595
|
||||||
fixme "ACAP: FIXME not yet implemented"
|
fixme "ACAP: FIXME not yet implemented"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
5222)
|
5222) # XMPP, see https://tools.ietf.org/html/rfc6120
|
||||||
|
starttls_just_read
|
||||||
|
# following would be without hostname, jabber.org doesn't need it, others do!
|
||||||
|
#starttls_line0 "<stream:stream xmlns:stream='http://etherx.jabber.org/streams' xmlns='jabber:client' version='1.0'>\r\n"
|
||||||
|
[ -z $JABBERNODE ] && JABBERNODE="$NODE"
|
||||||
|
# as ioerror says: $NODE is not always the correct one, some jabber implementations need a special hostname!
|
||||||
|
# supply $JABBERNODE in ENV and you're set, like: DEBUG=2 JABBERNODE=google.com ./heartbleed.bash talk.google.com:5222
|
||||||
|
jabber=$(cat <<EOF
|
||||||
|
<?xml version='1.0' ?>
|
||||||
|
<stream:stream
|
||||||
|
xmlns:stream='http://etherx.jabber.org/streams'
|
||||||
|
xmlns='jabber:client'
|
||||||
|
to='$JABBERNODE'
|
||||||
|
xml:lang='en'
|
||||||
|
version='1.0'>
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
starttls_line0 "$jabber"
|
||||||
starttls_line0 "<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>" "proceed"
|
starttls_line0 "<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>" "proceed"
|
||||||
fixme "XMPP: FIXME not yet implemented"
|
# BTW: https://xmpp.net !
|
||||||
;;
|
;;
|
||||||
443|995|993|465|*) # we don't need a special command here
|
443|995|993|465|*) # we don't need a special pre-command here
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
echo
|
echo
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
close_socket(){
|
close_socket(){
|
||||||
exec 5<&-
|
exec 5<&-
|
||||||
exec 5>&-
|
exec 5>&-
|
||||||
@ -282,4 +352,4 @@ echo
|
|||||||
exit $ret
|
exit $ret
|
||||||
|
|
||||||
# vim:tw=100:ts=5:sw=5:expandtab
|
# vim:tw=100:ts=5:sw=5:expandtab
|
||||||
# $Id: ccs-injection.bash,v 1.7 2015/07/01 17:48:00 dirkw Exp $
|
# $Id: ccs-injection.bash,v 1.9 2015/07/06 20:01:49 dirkw Exp $
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
# sockets inspired by http://blog.chris007.de/?p=238
|
# sockets inspired by http://blog.chris007.de/?p=238
|
||||||
# heartbleed mainly adapted from https://gist.github.com/takeshixx/10107280
|
# heartbleed mainly adapted from https://gist.github.com/takeshixx/10107280
|
||||||
#
|
#
|
||||||
|
# handshakes from RFCs. Good source too: https://github.com/ioerror/sslscan/blob/master/sslscan.c
|
||||||
|
#
|
||||||
###### DON'T DO EVIL! USAGE AT YOUR OWN RISK. DON'T VIOLATE LAWS! #######
|
###### DON'T DO EVIL! USAGE AT YOUR OWN RISK. DON'T VIOLATE LAWS! #######
|
||||||
|
|
||||||
readonly PS4='${LINENO}: ${FUNCNAME[0]:+${FUNCNAME[0]}(): }'
|
readonly PS4='${LINENO}: ${FUNCNAME[0]:+${FUNCNAME[0]}(): }'
|
||||||
@ -15,14 +17,17 @@ trap "cleanup" QUIT EXIT
|
|||||||
|
|
||||||
NODE="$1"
|
NODE="$1"
|
||||||
PORT="443"
|
PORT="443"
|
||||||
|
JABBERNODE=${JABBERNODE}
|
||||||
SLEEP=2
|
SLEEP=2
|
||||||
MAXSLEEP=10
|
MAXSLEEP=10
|
||||||
SOCKREPLY=""
|
SOCKREPLY=""
|
||||||
COL_WIDTH=32
|
COL_WIDTH=32
|
||||||
|
DEBUG=${DEBUG:-0}
|
||||||
|
|
||||||
# TLS 1.0=x01 1.1=0x02, 1.2=0x3
|
# TLS 1.0=x01 1.1=0x02, 1.2=0x3
|
||||||
TLSV=${2:-01}
|
TLSV=${2:-01}
|
||||||
|
|
||||||
|
|
||||||
heartbleed_payload="\x18\x03\x$TLSV\x00\x03\x01\x40\x00"
|
heartbleed_payload="\x18\x03\x$TLSV\x00\x03\x01\x40\x00"
|
||||||
## ^^^^^^^ this is the whole thing!
|
## ^^^^^^^ this is the whole thing!
|
||||||
|
|
||||||
@ -90,6 +95,11 @@ parse_hn_port() {
|
|||||||
echo -e "\n===> connecting to $NODE:$PORT\n"
|
echo -e "\n===> connecting to $NODE:$PORT\n"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
debugme() {
|
||||||
|
[[ $DEBUG -ge 2 ]] && "$@"
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
wait_kill(){
|
wait_kill(){
|
||||||
pid=$1
|
pid=$1
|
||||||
maxsleep=$2
|
maxsleep=$2
|
||||||
@ -124,33 +134,37 @@ sockread() {
|
|||||||
wait_kill $! $maxsleep
|
wait_kill $! $maxsleep
|
||||||
ret=$?
|
ret=$?
|
||||||
SOCKREPLY=$(cat $ddreply)
|
SOCKREPLY=$(cat $ddreply)
|
||||||
rm $ddreply
|
[ $DEBUG -eq 0 ] && rm $ddreply
|
||||||
|
|
||||||
return $ret
|
return $ret
|
||||||
}
|
}
|
||||||
|
|
||||||
# arg1: string to send
|
|
||||||
# arg2: success string, yet to be parsed
|
starttls_just_read(){
|
||||||
starttls_line0() {
|
echo "=== just read banner ==="
|
||||||
echo "$1" >&5
|
|
||||||
cat <&5 &
|
cat <&5 &
|
||||||
wait_kill $! $SLEEP
|
wait_kill $! $SLEEP
|
||||||
#[ $? -eq 3 ] && fixme "STARTTLS timed out" && exit 1
|
|
||||||
}
|
}
|
||||||
|
|
||||||
starttls_line2() {
|
# arg1: string to send
|
||||||
|
# arg2: possible success strings a egrep pattern, needed!
|
||||||
|
starttls_line0() {
|
||||||
reply=$(mktemp /tmp/reply.XXXXXX) || return 7
|
reply=$(mktemp /tmp/reply.XXXXXX) || return 7
|
||||||
echo "$1" >&5
|
|
||||||
dd bs=1024 of=$reply count=1 <&5 2>/dev/null &
|
debugme echo -e "\n=== sending \"$1\" ..."
|
||||||
|
echo -e "$1" >&5
|
||||||
|
dd bs=1024 of=$reply count=32 <&5 2>/dev/null &
|
||||||
wait_kill $! $SLEEP
|
wait_kill $! $SLEEP
|
||||||
|
debugme echo "... received result: "
|
||||||
cat $reply
|
cat $reply
|
||||||
return 0
|
|
||||||
if [ -n "$2" ]; then
|
if [ -n "$2" ]; then
|
||||||
if grep -q "$2" $reply; then
|
if egrep -q "$2" $reply; then
|
||||||
|
debugme echo "---> reply matched \"$2\""
|
||||||
|
[ $DEBUG -eq 0 ] && rm $reply
|
||||||
return 0
|
return 0
|
||||||
else
|
else
|
||||||
|
debugme echo "---> reply didn't match \"$2\", see $reply"
|
||||||
fixme "STARTTLS handshake problem"
|
fixme "STARTTLS handshake problem"
|
||||||
#FIXME: handshake antworten kommen irgendwie 1x verzeogert
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -171,6 +185,8 @@ fixme(){
|
|||||||
|
|
||||||
|
|
||||||
fd_socket(){
|
fd_socket(){
|
||||||
|
local jabber=""
|
||||||
|
|
||||||
if ! exec 5<> /dev/tcp/$NODE/$PORT; then
|
if ! exec 5<> /dev/tcp/$NODE/$PORT; then
|
||||||
echo "`basename $0`: unable to connect to $NODE:$PORT"
|
echo "`basename $0`: unable to connect to $NODE:$PORT"
|
||||||
exit 2
|
exit 2
|
||||||
@ -178,37 +194,60 @@ fd_socket(){
|
|||||||
|
|
||||||
case "$1" in # port
|
case "$1" in # port
|
||||||
21) # https://tools.ietf.org/html/rfc4217
|
21) # https://tools.ietf.org/html/rfc4217
|
||||||
starttls_line0 "FEAT"
|
starttls_just_read
|
||||||
starttls_line0 "AUTH TLS" "successful"
|
starttls_line0 "FEAT" "211"
|
||||||
|
#starttls_line0 HELP "214"
|
||||||
|
starttls_line0 "AUTH TLS" "successful|234"
|
||||||
;;
|
;;
|
||||||
25) #https://tools.ietf.org/html/rfc4217
|
25) # SMTP, see https://tools.ietf.org/html/rfc4217
|
||||||
starttls_line0 "EHLO testssl.sh" "250"
|
starttls_just_read
|
||||||
|
starttls_line0 "EHLO testssl.sh" "220|250"
|
||||||
starttls_line0 "STARTTLS" "220"
|
starttls_line0 "STARTTLS" "220"
|
||||||
;;
|
;;
|
||||||
110) # https://tools.ietf.org/html/rfc2595
|
110) # POP, see https://tools.ietf.org/html/rfc2595
|
||||||
|
starttls_just_read
|
||||||
starttls_line0 "STLS" "OK"
|
starttls_line0 "STLS" "OK"
|
||||||
;;
|
;;
|
||||||
119|433) # https://tools.ietf.org/html/rfc4642
|
119|433) # NNTP, see https://tools.ietf.org/html/rfc4642
|
||||||
starttls_line0 "CAPABILITIES" "101"
|
starttls_just_read
|
||||||
|
starttls_line0 "CAPABILITIES" "101|200"
|
||||||
starttls_line0 "STARTTLS" "382"
|
starttls_line0 "STARTTLS" "382"
|
||||||
;;
|
;;
|
||||||
143) # https://tools.ietf.org/html/rfc2595
|
143) # IMAP, https://tools.ietf.org/html/rfc2595
|
||||||
|
starttls_just_read
|
||||||
starttls_line0 "a001 CAPABILITY" "OK"
|
starttls_line0 "a001 CAPABILITY" "OK"
|
||||||
starttls_line0 "a002 STARTTLS" "OK"
|
starttls_line0 "a002 STARTTLS" "OK"
|
||||||
;;
|
;;
|
||||||
389) # https://tools.ietf.org/html/rfc2830, https://tools.ietf.org/html/rfc4511
|
389) # LDAP, https://tools.ietf.org/html/rfc2830, https://tools.ietf.org/html/rfc4511
|
||||||
fixme "LDAP: FIXME not yet implemented"
|
fixme "LDAP: FIXME not yet implemented"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
674) # https://tools.ietf.org/html/rfc2595
|
674) # ACAP = Application Configuration Access Protocol, see https://tools.ietf.org/html/rfc2595
|
||||||
fixme "ACAP: FIXME not yet implemented"
|
fixme "ACAP: FIXME not yet implemented"
|
||||||
exit 1
|
exit 1
|
||||||
;;
|
;;
|
||||||
5222)
|
5222) # XMPP, see https://tools.ietf.org/html/rfc6120
|
||||||
|
starttls_just_read
|
||||||
|
# following would be without hostname, jabber.org doesn't need it, others do!
|
||||||
|
#starttls_line0 "<stream:stream xmlns:stream='http://etherx.jabber.org/streams' xmlns='jabber:client' version='1.0'>\r\n"
|
||||||
|
[ -z $JABBERNODE ] && JABBERNODE="$NODE"
|
||||||
|
# as ioerror says: $NODE is not always the correct one, some jabber implementations need a special hostname!
|
||||||
|
# supply $JABBERNODE in ENV and you're set, like: DEBUG=2 JABBERNODE=google.com ./heartbleed.bash talk.google.com:5222
|
||||||
|
jabber=$(cat <<EOF
|
||||||
|
<?xml version='1.0' ?>
|
||||||
|
<stream:stream
|
||||||
|
xmlns:stream='http://etherx.jabber.org/streams'
|
||||||
|
xmlns='jabber:client'
|
||||||
|
to='$JABBERNODE'
|
||||||
|
xml:lang='en'
|
||||||
|
version='1.0'>
|
||||||
|
EOF
|
||||||
|
)
|
||||||
|
starttls_line0 "$jabber"
|
||||||
starttls_line0 "<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>" "proceed"
|
starttls_line0 "<starttls xmlns='urn:ietf:params:xml:ns:xmpp-tls'/>" "proceed"
|
||||||
fixme "XMPP: FIXME not yet implemented"
|
# BTW: https://xmpp.net !
|
||||||
;;
|
;;
|
||||||
443|995|993|465|*) # we don't need a special command here
|
443|995|993|465|*) # we don't need a special pre-command here
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
echo
|
echo
|
||||||
@ -263,5 +302,5 @@ echo
|
|||||||
|
|
||||||
exit $ret
|
exit $ret
|
||||||
|
|
||||||
# vim:tw=100:ts=5:sw=5:expandtab
|
# vim:tw=200:ts=5:sw=5:expandtab
|
||||||
# $Id: heartbleed.bash,v 1.12 2015/07/01 11:26:10 dirkw Exp $
|
# $Id: heartbleed.bash,v 1.14 2015/07/06 19:26:38 dirkw Exp $
|
||||||
|
Loading…
Reference in New Issue
Block a user