mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-22 08:29:31 +01:00
Fix single cipher and JSON pretty
testssl.sh produces an invalid JSON file if the --json-pretty option is used with the --single-cipher option. The reason is that fileout_section_header() isn't called before run_cipher_match() calls fileout() and fileout_section_footer() is not called afterwards. There is also a problem with MEASURE_TIME, since the "cleanup" at the end of lets_roll() is not performed. This PR fixes these problems by adding a call to fileout_section_header() before the call to run_cipher_match() and by copying the code from the end of lets_roll() to run_cipher_match() (just before the call to exit).
This commit is contained in:
parent
b5c92e9a90
commit
fa063ccd98
36
testssl.sh
36
testssl.sh
@ -627,17 +627,18 @@ fileout_json_footer() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
fileout_json_section() {
|
fileout_json_section() {
|
||||||
case $1 in
|
case $1 in
|
||||||
1) echo -e " \"protocols\" : [" ;;
|
1) echo -e " \"singleCipher\" : [" ;;
|
||||||
2) echo -e ",\n \"ciphers\" : [" ;;
|
2) echo -e " \"protocols\" : [" ;;
|
||||||
3) echo -e ",\n \"pfs\" : [" ;;
|
3) echo -e ",\n \"ciphers\" : [" ;;
|
||||||
4) echo -e ",\n \"serverPreferences\" : [" ;;
|
4) echo -e ",\n \"pfs\" : [" ;;
|
||||||
5) echo -e ",\n \"serverDefaults\" : [" ;;
|
5) echo -e ",\n \"serverPreferences\" : [" ;;
|
||||||
6) echo -e ",\n \"headerResponse\" : [" ;;
|
6) echo -e ",\n \"serverDefaults\" : [" ;;
|
||||||
7) echo -e ",\n \"vulnerabilities\" : [" ;;
|
7) echo -e ",\n \"headerResponse\" : [" ;;
|
||||||
8) echo -e ",\n \"cipherTests\" : [" ;;
|
8) echo -e ",\n \"vulnerabilities\" : [" ;;
|
||||||
9) echo -e ",\n \"browserSimulations\": [" ;;
|
9) echo -e ",\n \"cipherTests\" : [" ;;
|
||||||
*) echo "invalid section" ;;
|
10) echo -e ",\n \"browserSimulations\": [" ;;
|
||||||
|
*) echo "invalid section" ;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2797,6 +2798,16 @@ run_cipher_match(){
|
|||||||
fileout "cipher_${normalized_hexcode[i]}" "INFO" "$(neat_list "${normalized_hexcode[i]}" "${ciph[i]}" "${kx[i]}" "${enc[i]}") $available"
|
fileout "cipher_${normalized_hexcode[i]}" "INFO" "$(neat_list "${normalized_hexcode[i]}" "${ciph[i]}" "${kx[i]}" "${enc[i]}") $available"
|
||||||
done
|
done
|
||||||
"$using_sockets" && HAS_DH_BITS="$has_dh_bits"
|
"$using_sockets" && HAS_DH_BITS="$has_dh_bits"
|
||||||
|
tmpfile_handle $FUNCNAME.txt
|
||||||
|
time_right_align run_cipher_match
|
||||||
|
fileout_section_footer true
|
||||||
|
outln
|
||||||
|
END_TIME=$(date +%s)
|
||||||
|
SCAN_TIME=$(( END_TIME - START_TIME ))
|
||||||
|
datebanner " Done"
|
||||||
|
|
||||||
|
"$MEASURE_TIME" && printf "%${COLUMNS}s\n" "$SCAN_TIME"
|
||||||
|
[[ -e "$MEASURE_TIME_FILE" ]] && echo "Total : $SCAN_TIME " >> "$MEASURE_TIME_FILE"
|
||||||
exit
|
exit
|
||||||
done
|
done
|
||||||
outln
|
outln
|
||||||
@ -13491,7 +13502,8 @@ lets_roll() {
|
|||||||
|
|
||||||
$do_tls_sockets && [[ $TLS_LOW_BYTE -eq 22 ]] && { sslv2_sockets "" "true"; echo "$?" ; exit 0; }
|
$do_tls_sockets && [[ $TLS_LOW_BYTE -eq 22 ]] && { sslv2_sockets "" "true"; echo "$?" ; exit 0; }
|
||||||
$do_tls_sockets && [[ $TLS_LOW_BYTE -ne 22 ]] && { tls_sockets "$TLS_LOW_BYTE" "$HEX_CIPHER" "all"; echo "$?" ; exit 0; }
|
$do_tls_sockets && [[ $TLS_LOW_BYTE -ne 22 ]] && { tls_sockets "$TLS_LOW_BYTE" "$HEX_CIPHER" "all"; echo "$?" ; exit 0; }
|
||||||
$do_cipher_match && run_cipher_match ${single_cipher} && time_right_align
|
$do_cipher_match && { fileout_section_header $section_number false; run_cipher_match ${single_cipher}; }
|
||||||
|
((section_number++))
|
||||||
|
|
||||||
# all top level functions now following have the prefix "run_"
|
# all top level functions now following have the prefix "run_"
|
||||||
fileout_section_header $section_number false && ((section_number++))
|
fileout_section_header $section_number false && ((section_number++))
|
||||||
|
Loading…
Reference in New Issue
Block a user