From 101fde5f2f3d47d81debb3e46ad5b79212d58b1c Mon Sep 17 00:00:00 2001 From: Jussi-Pekka Erkkila Date: Sun, 1 Dec 2024 23:45:26 +0200 Subject: [PATCH] add target url to cmd output --- secheaders/cmd_utils.py | 13 ++++++------- secheaders/securityheaders.py | 2 +- 2 files changed, 7 insertions(+), 8 deletions(-) diff --git a/secheaders/cmd_utils.py b/secheaders/cmd_utils.py index 9b837d5..a58cfa5 100644 --- a/secheaders/cmd_utils.py +++ b/secheaders/cmd_utils.py @@ -20,19 +20,18 @@ def get_eval_output(warn, no_color): return f"[ {color_start}{eval_result}{color_end} ]" -def output_text(headers, https, verbose=False, no_color=False) -> str: +def output_text(target_url, headers, https, args) -> str: terminal_width = shutil.get_terminal_size().columns - output_str = "" + output_str = f"Scan target: {target_url}\n" # If the stdout is not going into terminal, disable colors - no_color = no_color or not sys.stdout.isatty() + no_color = args.no_color or not sys.stdout.isatty() for header, value in headers.items(): truncated = False - header_contents = value['contents'] if not value['defined']: output = f"Header '{header}' is missing" else: - output = f"{header}: {header_contents}" + output = f"{header}: {value['contents']}" if len(output) > terminal_width - COLUMN_WIDTH_R: truncated = True output = f"{output[0:(terminal_width - COLUMN_WIDTH_R - 3)]}..." @@ -45,8 +44,8 @@ def output_text(headers, https, verbose=False, no_color=False) -> str: # This is a dirty hack required to align ANSI-colored str correctly output_str += f"{output:<{terminal_width - COLUMN_WIDTH_R}}{eval_value:^{COLUMN_WIDTH_R + 9}}\n" - if truncated and verbose: - output_str += f"Full header contents: {header_contents}\n" + if truncated and args.verbose: + output_str += f"Full header contents: {value['contents']}\n" for note in value['notes']: output_str += textwrap.fill(f" * {note}", terminal_width - COLUMN_WIDTH_R, subsequent_indent=' ') output_str += "\n" diff --git a/secheaders/securityheaders.py b/secheaders/securityheaders.py index 9c331e0..27a050d 100644 --- a/secheaders/securityheaders.py +++ b/secheaders/securityheaders.py @@ -223,7 +223,7 @@ def main(): if args.json: print(json.dumps({'target': header_check.get_full_url(), 'headers': headers, 'https': https}, indent=2)) else: - print(cmd_utils.output_text(headers, https, args.verbose, args.no_color)) + print(cmd_utils.output_text(header_check.get_full_url(), headers, https, args)) if __name__ == "__main__":