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:
David Cooper 2017-02-14 13:44:03 -05:00 committed by GitHub
parent 308b24cbe9
commit 48088bbceb

View File

@ -977,7 +977,6 @@ 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"
@ -996,7 +995,6 @@ html_header() {
out_html "</head>\n" out_html "</head>\n"
out_html "<body>\n" out_html "<body>\n"
out_html "<pre>\n" out_html "<pre>\n"
fi
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