mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-10 02:30:58 +01:00
Now with JSON and CSV support - Final commit
This commit is contained in:
parent
d69bd246a9
commit
0bbc0a6a48
@ -66,8 +66,11 @@
|
|||||||
* Dmitri S
|
* Dmitri S
|
||||||
- inspiration & help for Darwin port
|
- inspiration & help for Darwin port
|
||||||
|
|
||||||
|
* Frank Breedijk
|
||||||
|
- JSON and CSV output
|
||||||
|
|
||||||
* Bug reports:
|
* Bug reports:
|
||||||
- Viktor Szépe, Olivier Paroz, Jan H. Terstegge, Lorenz Adena, Jonathon Rossi, Stefan Stidl
|
- Viktor Szépe, Olivier Paroz, Jan H. Terstegge, Lorenz Adena, Jonathon Rossi, Stefan Stidl, Frank Breedijk
|
||||||
|
|
||||||
##### Last but not least:
|
##### Last but not least:
|
||||||
|
|
||||||
|
39
testssl.sh
39
testssl.sh
@ -135,6 +135,7 @@ DEBUG=${DEBUG:-0} # 1.: the temp files won't be erased.
|
|||||||
WIDE=${WIDE:-false} # whether to display for some options the cipher or the table with hexcode/KX,Enc,strength etc.
|
WIDE=${WIDE:-false} # whether to display for some options the cipher or the table with hexcode/KX,Enc,strength etc.
|
||||||
LOGFILE=${LOGILE-""} # logfile if used
|
LOGFILE=${LOGILE-""} # logfile if used
|
||||||
JSONFILE="testssl.json" # jsonfile if used
|
JSONFILE="testssl.json" # jsonfile if used
|
||||||
|
CSVFILE="testssl.csv" # csvfile if used
|
||||||
HAS_IPv6=${HAS_IPv6:-false} # if you have OPENSSL with IPv6 support AND IPv6 networking set it to yes and testssl.sh works!
|
HAS_IPv6=${HAS_IPv6:-false} # if you have OPENSSL with IPv6 support AND IPv6 networking set it to yes and testssl.sh works!
|
||||||
|
|
||||||
# tuning vars, can not be set by a cmd line switch
|
# tuning vars, can not be set by a cmd line switch
|
||||||
@ -407,20 +408,27 @@ set_color_functions() {
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
open_json_file() {
|
strip_quote() {
|
||||||
if $do_json; then
|
echo $1|sed "s/\"/\\'/g" # Fix syntax highlighting
|
||||||
|
}
|
||||||
|
|
||||||
|
file_header() {
|
||||||
|
if [[ $do_json ]]; then
|
||||||
echo "[" > $JSONFILE
|
echo "[" > $JSONFILE
|
||||||
fi
|
fi
|
||||||
|
if [[ $do_csv ]]; then
|
||||||
|
echo "\"id\",\"ip\",\"port\",\"severity\",\"finding\"" > $CSVFILE
|
||||||
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
close_json_file() {
|
file_footer() {
|
||||||
if $do_json; then
|
if [[ $do_json ]]; then
|
||||||
echo "]" >> $JSONFILE
|
echo "]" >> $JSONFILE
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
output_finding() { # ID, IP, PORT, SEVERITY, FINDING
|
output_finding() { # ID, IP, PORT, SEVERITY, FINDING
|
||||||
if $do_json; then
|
if [[ $do_json ]]; then
|
||||||
if ! $FIRST_FINDING; then
|
if ! $FIRST_FINDING; then
|
||||||
echo "," >> $JSONFILE
|
echo "," >> $JSONFILE
|
||||||
fi
|
fi
|
||||||
@ -433,6 +441,9 @@ output_finding() { # ID, IP, PORT, SEVERITY, FINDING
|
|||||||
'finding' : '$5'
|
'finding' : '$5'
|
||||||
}" >> $JSONFILE
|
}" >> $JSONFILE
|
||||||
fi
|
fi
|
||||||
|
if [[ $do_csv ]]; then
|
||||||
|
echo -e "\"$(strip_quote "$1")\",\"$(strip_quote "$2")\",\"$(strip_quote "$3")\",\"$(strip_quote "$4")\",\"$(strip_quote "$5")\"" >>$CSVFILE
|
||||||
|
fi
|
||||||
if $FIRST_FINDING; then
|
if $FIRST_FINDING; then
|
||||||
FIRST_FINDING=false
|
FIRST_FINDING=false
|
||||||
fi
|
fi
|
||||||
@ -4643,7 +4654,9 @@ tuning options (can also be preset via environment variables):
|
|||||||
|
|
||||||
output options:
|
output options:
|
||||||
--json output all findngs to a json file (defaults to testssl.json unless set)
|
--json output all findngs to a json file (defaults to testssl.json unless set)
|
||||||
--jsonfile <fname> set output to json and output to the specified file
|
--jsonfile <fname> set output to json and output json to the specified file
|
||||||
|
--csv output all findngs to a csv file (defaults to testssl.csv unless set)
|
||||||
|
--csvfile <fname> set output to csv and output csv to the specified file
|
||||||
|
|
||||||
All options requiring a value can also be called with '=' (e.g. testssl.sh -t=smtp --wide --openssl=/usr/bin/openssl <URI>.
|
All options requiring a value can also be called with '=' (e.g. testssl.sh -t=smtp --wide --openssl=/usr/bin/openssl <URI>.
|
||||||
<URI> is always the last parameter.
|
<URI> is always the last parameter.
|
||||||
@ -5451,6 +5464,7 @@ initialize_globals() {
|
|||||||
do_mass_testing=false
|
do_mass_testing=false
|
||||||
do_logging=false
|
do_logging=false
|
||||||
do_json=false
|
do_json=false
|
||||||
|
do_csv=false
|
||||||
do_pfs=false
|
do_pfs=false
|
||||||
do_protocols=false
|
do_protocols=false
|
||||||
do_rc4=false
|
do_rc4=false
|
||||||
@ -5764,6 +5778,15 @@ parse_cmd_line() {
|
|||||||
[[ $? -eq 0 ]] && shift
|
[[ $? -eq 0 ]] && shift
|
||||||
do_json=true
|
do_json=true
|
||||||
;;
|
;;
|
||||||
|
--csv)
|
||||||
|
do_csv=true
|
||||||
|
;; # DEFINITION of CSVFILE is not arg specified via ENV or automagically in parse_hn_ports()
|
||||||
|
# following does the same but we can specify a log location additionally
|
||||||
|
--csvfile=*)
|
||||||
|
CSVFILE=$(parse_opt_equal_sign "$1" "$2")
|
||||||
|
[[ $? -eq 0 ]] && shift
|
||||||
|
do_csv=true
|
||||||
|
;;
|
||||||
--openssl|--openssl=*)
|
--openssl|--openssl=*)
|
||||||
OPENSSL=$(parse_opt_equal_sign "$1" "$2")
|
OPENSSL=$(parse_opt_equal_sign "$1" "$2")
|
||||||
[[ $? -eq 0 ]] && shift
|
[[ $? -eq 0 ]] && shift
|
||||||
@ -5906,7 +5929,7 @@ maketempf
|
|||||||
mybanner
|
mybanner
|
||||||
check_proxy
|
check_proxy
|
||||||
openssl_age
|
openssl_age
|
||||||
open_json_file
|
file_header
|
||||||
|
|
||||||
# TODO: it is ugly to have those two vars here --> main()
|
# TODO: it is ugly to have those two vars here --> main()
|
||||||
ret=0
|
ret=0
|
||||||
@ -5952,7 +5975,7 @@ else
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
close_json_file
|
file_footer
|
||||||
|
|
||||||
exit $?
|
exit $?
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user