mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-03 23:39:45 +01:00
word match for -V / -x now only for non-numbers: testssh.sh -x cc google.com tests for chaha ciphers
(before only word matching was done e.g.: testssl.sh -x ECDH chase.com
This commit is contained in:
parent
473c9c1e3a
commit
66f0b22adb
31
testssl.sh
31
testssl.sh
@ -948,9 +948,15 @@ normalize_ciphercode() {
|
||||
}
|
||||
|
||||
prettyprint_local() {
|
||||
local arg
|
||||
local hexcode dash ciph sslvers kx auth enc mac export
|
||||
local re='^[0-9A-Fa-f]+$'
|
||||
|
||||
pr_blue "--> Displaying all local ciphers ";
|
||||
if [[ -n "$1" ]]; then
|
||||
pr_blue "matching word pattern "\"$1\"" (ignore case)";
|
||||
[[ $1 =~ $re ]] && \
|
||||
pr_blue "matching number pattern \"$1\" " || \
|
||||
pr_blue "matching word pattern "\"$1\"" (ignore case)"
|
||||
fi
|
||||
outln "\n"
|
||||
neat_header
|
||||
@ -965,6 +971,9 @@ prettyprint_local() {
|
||||
for arg in $(echo $@ | sed 's/,/ /g'); do
|
||||
$OPENSSL ciphers -V 'ALL:COMPLEMENTOFALL:@STRENGTH' | while read hexcode dash ciph sslvers kx auth enc mac export ; do # -V doesn't work with openssl < 1.0
|
||||
normalize_ciphercode $hexcode
|
||||
# for numbers we don't do word matching:
|
||||
[[ $arg =~ $re ]] && \
|
||||
neat_list $HEXC $ciph $kx $enc | grep -ai "$arg" || \
|
||||
neat_list $HEXC $ciph $kx $enc | grep -wai "$arg"
|
||||
done
|
||||
done
|
||||
@ -1099,8 +1108,13 @@ test_just_one(){
|
||||
local hexcode n ciph sslvers kx auth enc mac export
|
||||
local dhlen
|
||||
local ret
|
||||
local re='^[0-9A-Fa-f]+$'
|
||||
|
||||
pr_blue "--> Testing single cipher with word pattern "\"$1\"" (ignore case)"; outln
|
||||
pr_blue "--> Testing single cipher with "
|
||||
[[ $1 =~ $re ]] && \
|
||||
pr_blue "matching number pattern \"$1\" " || \
|
||||
pr_blue "word pattern "\"$1\"" (ignore case)"
|
||||
outln
|
||||
! $HAS_DH_BITS && pr_litemagentaln " (Your $OPENSSL cannot show DH/ECDH bits)"
|
||||
outln
|
||||
neat_header
|
||||
@ -1109,7 +1123,12 @@ test_just_one(){
|
||||
$OPENSSL ciphers -V 'ALL:COMPLEMENTOFALL:@STRENGTH' | while read hexcode dash ciph sslvers kx auth enc mac export ; do
|
||||
# FIXME: e.g. OpenSSL < 1.0 doesn't understand "-V" --> we can't do anything about it!
|
||||
normalize_ciphercode $hexcode
|
||||
# is argument a number?
|
||||
if [[ $arg =~ $re ]]; then
|
||||
neat_list $HEXC $ciph $kx $enc | grep -qai "$arg"
|
||||
else
|
||||
neat_list $HEXC $ciph $kx $enc | grep -qwai "$arg"
|
||||
fi
|
||||
if [[ $? -eq 0 ]]; then # string matches, so we can ssl to it:
|
||||
$OPENSSL s_client -cipher $ciph $STARTTLS -connect $NODEIP:$PORT $PROXY $SNI &>$TMPFILE </dev/null
|
||||
ret=$?
|
||||
@ -3542,7 +3561,8 @@ $PROG_NAME <options>
|
||||
-b, --banner displays banner + version of $PROG_NAME
|
||||
-v, --version same as previous
|
||||
-V, --local pretty print all local ciphers
|
||||
-V, --local <pattern> what local cipher with <pattern> is available?
|
||||
-V, --local <pattern> which local ciphers with <pattern> are available?
|
||||
(if pattern not a number: word match)
|
||||
|
||||
$PROG_NAME <options> URI ("$PROG_NAME URI" does everything except -E)
|
||||
|
||||
@ -3553,7 +3573,8 @@ $PROG_NAME <options> URI ("$PROG_NAME URI" does everything except -E)
|
||||
-S, --server_defaults displays the servers default picks and certificate info
|
||||
-P, --preference displays the servers picks: protocol+cipher
|
||||
-y, --spdy, --npn checks for SPDY/NPN
|
||||
-x, --single-cipher <pattern> tests matched <pattern> of cipher
|
||||
-x, --single-cipher <pattern> tests matched <pattern> of ciphers
|
||||
(if <pattern> not a number: word match)
|
||||
-U, --vulnerable tests all vulnerabilities
|
||||
-B, --heartbleed tests for heartbleed vulnerability
|
||||
-I, --ccs, --ccs-injection tests for CCS injection vulnerability
|
||||
@ -4496,4 +4517,4 @@ fi
|
||||
exit $ret
|
||||
|
||||
|
||||
# $Id: testssl.sh,v 1.321 2015/07/17 12:58:11 dirkw Exp $
|
||||
# $Id: testssl.sh,v 1.322 2015/07/17 13:58:06 dirkw Exp $
|
||||
|
Loading…
Reference in New Issue
Block a user