mirror of
https://github.com/drwetter/testssl.sh.git
synced 2025-01-07 17:20:57 +01:00
Cleanup
Rearrange code so that in the case of just a single test, `parse_hn_port()` is not called earlier than it was previously unless it needs to be called in order to create the HTML file name. Doing this ensures that the banner is displayed even if the `$URI` cannot be parsed (except in the case that the `$URI` needs to be parsed in order to create a file name) and that any error messages created by `parse_hn_port()` will be included in the HTML, if possible.
This commit is contained in:
parent
308b24cbe9
commit
48088bbceb
42
testssl.sh
42
testssl.sh
@ -977,26 +977,24 @@ fileout() { # ID, SEVERITY, FINDING, CVE, CWE, HINT
|
|||||||
html_header() {
|
html_header() {
|
||||||
local fname_prefix="$1"
|
local fname_prefix="$1"
|
||||||
|
|
||||||
if "$HTMLHEADER"; then
|
[[ -z "$fname_prefix" ]] && fname_prefix="$NODE"_"$PORT"
|
||||||
[[ -z "$fname_prefix" ]] && fname_prefix="$NODE"_"$PORT"
|
if [[ -n "$HTMLFILE" ]] && [[ ! -d "$HTMLFILE" ]]; then
|
||||||
if [[ -n "$HTMLFILE" ]] && [[ ! -d "$HTMLFILE" ]]; then
|
rm -f "$HTMLFILE"
|
||||||
rm -f "$HTMLFILE"
|
elif [[ -z "$HTMLFILE" ]]; then
|
||||||
elif [[ -z "$HTMLFILE" ]]; then
|
HTMLFILE=$fname_prefix-$(date +"%Y%m%d-%H%M".html)
|
||||||
HTMLFILE=$fname_prefix-$(date +"%Y%m%d-%H%M".html)
|
else
|
||||||
else
|
HTMLFILE=$HTMLFILE/$fname_prefix-$(date +"%Y%m%d-%H%M".html)
|
||||||
HTMLFILE=$HTMLFILE/$fname_prefix-$(date +"%Y%m%d-%H%M".html)
|
|
||||||
fi
|
|
||||||
out_html "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n"
|
|
||||||
out_html "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\n"
|
|
||||||
out_html "<!-- This file was created with testssl.sh. https://testssl.sh -->\n"
|
|
||||||
out_html "<html xmlns=\"http://www.w3.org/1999/xhtml\">\n"
|
|
||||||
out_html "<head>\n"
|
|
||||||
out_html "<meta http-equiv=\"Content-Type\" content=\"application/xml+xhtml; charset=UTF-8\" />\n"
|
|
||||||
out_html "<title>testssl.sh</title>\n"
|
|
||||||
out_html "</head>\n"
|
|
||||||
out_html "<body>\n"
|
|
||||||
out_html "<pre>\n"
|
|
||||||
fi
|
fi
|
||||||
|
out_html "<?xml version=\"1.0\" encoding=\"UTF-8\" ?>\n"
|
||||||
|
out_html "<!DOCTYPE html PUBLIC \"-//W3C//DTD XHTML 1.0 Strict//EN\" \"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd\">\n"
|
||||||
|
out_html "<!-- This file was created with testssl.sh. https://testssl.sh -->\n"
|
||||||
|
out_html "<html xmlns=\"http://www.w3.org/1999/xhtml\">\n"
|
||||||
|
out_html "<head>\n"
|
||||||
|
out_html "<meta http-equiv=\"Content-Type\" content=\"application/xml+xhtml; charset=UTF-8\" />\n"
|
||||||
|
out_html "<title>testssl.sh</title>\n"
|
||||||
|
out_html "</head>\n"
|
||||||
|
out_html "<body>\n"
|
||||||
|
out_html "<pre>\n"
|
||||||
return 0
|
return 0
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -12999,7 +12997,8 @@ lets_roll() {
|
|||||||
|
|
||||||
initialize_globals
|
initialize_globals
|
||||||
parse_cmd_line "$@"
|
parse_cmd_line "$@"
|
||||||
if ! "$do_mass_testing" || ( [[ -n "$HTMLFILE" ]] && [[ ! -d "$HTMLFILE" ]] ); then
|
! "$do_html" && HTMLHEADER=false
|
||||||
|
if "$HTMLHEADER" && ( ! "$do_mass_testing" || ( [[ -n "$HTMLFILE" ]] && [[ ! -d "$HTMLFILE" ]] ) ); then
|
||||||
if "$do_display_only"; then
|
if "$do_display_only"; then
|
||||||
html_header "local-ciphers"
|
html_header "local-ciphers"
|
||||||
elif "$do_mass_testing"; then
|
elif "$do_mass_testing"; then
|
||||||
@ -13007,7 +13006,7 @@ if ! "$do_mass_testing" || ( [[ -n "$HTMLFILE" ]] && [[ ! -d "$HTMLFILE" ]] ); t
|
|||||||
elif "$do_mx_all_ips"; then
|
elif "$do_mx_all_ips"; then
|
||||||
html_header "mx-$URI"
|
html_header "mx-$URI"
|
||||||
else
|
else
|
||||||
parse_hn_port "${URI}" # NODE, URL_PATH, PORT, IPADDR and IP46ADDR is set now
|
( [[ -z "$HTMLFILE" ]] || [[ -d "$HTMLFILE" ]] ) && parse_hn_port "${URI}" # NODE, URL_PATH, PORT, IPADDR and IP46ADDR is set now
|
||||||
html_header
|
html_header
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
@ -13043,6 +13042,7 @@ if $do_mx_all_ips; then
|
|||||||
run_mx_all_ips "${URI}" $PORT # we should reduce run_mx_all_ips to the stuff neccessary as ~15 lines later we have sililar code
|
run_mx_all_ips "${URI}" $PORT # we should reduce run_mx_all_ips to the stuff neccessary as ~15 lines later we have sililar code
|
||||||
ret=$?
|
ret=$?
|
||||||
else
|
else
|
||||||
|
[[ -z "$NODE" ]] && parse_hn_port "${URI}" # NODE, URL_PATH, PORT, IPADDR and IP46ADDR is set now
|
||||||
prepare_logging
|
prepare_logging
|
||||||
if ! determine_ip_addresses; then
|
if ! determine_ip_addresses; then
|
||||||
fatal "No IP address could be determined" 2
|
fatal "No IP address could be determined" 2
|
||||||
|
Loading…
Reference in New Issue
Block a user