Renato Botelho do Couto | ead1e53 | 2019-10-31 13:31:07 -0500 | [diff] [blame] | 1 | #!/usr/bin/env python3 |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 2 | |
| 3 | import sys |
| 4 | import os |
| 5 | import logging |
| 6 | |
| 7 | """ @var formatting delimiter consisting of '=' characters """ |
Klement Sekera | 52e84f3 | 2017-01-13 07:25:25 +0100 | [diff] [blame] | 8 | double_line_delim = '=' * 78 |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 9 | """ @var formatting delimiter consisting of '-' characters """ |
Klement Sekera | 52e84f3 | 2017-01-13 07:25:25 +0100 | [diff] [blame] | 10 | single_line_delim = '-' * 78 |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 11 | |
| 12 | |
| 13 | def colorize(msg, color): |
| 14 | return color + msg + COLOR_RESET |
| 15 | |
| 16 | |
| 17 | class ColorFormatter(logging.Formatter): |
| 18 | |
| 19 | def init(self, fmt=None, datefmt=None): |
| 20 | super(ColorFormatter, self).__init__(fmt, datefmt) |
| 21 | |
| 22 | def format(self, record): |
| 23 | message = super(ColorFormatter, self).format(record) |
| 24 | if hasattr(record, 'color'): |
| 25 | message = colorize(message, record.color) |
| 26 | return message |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 27 | try: |
| 28 | verbose = int(os.getenv("V", 0)) |
| 29 | except: |
| 30 | verbose = 0 |
| 31 | |
| 32 | # 40 = ERROR, 30 = WARNING, 20 = INFO, 10 = DEBUG, 0 = NOTSET (all messages) |
| 33 | if verbose >= 2: |
| 34 | log_level = 10 |
| 35 | elif verbose == 1: |
| 36 | log_level = 20 |
| 37 | else: |
| 38 | log_level = 40 |
| 39 | |
Klement Sekera | 6c7440c | 2016-12-23 09:16:39 +0100 | [diff] [blame] | 40 | handler = logging.StreamHandler(sys.stdout) |
juraj.linkes | 184870a | 2018-07-16 14:22:01 +0200 | [diff] [blame] | 41 | color_formatter = ColorFormatter(fmt='%(asctime)s,%(msecs)03d %(message)s', |
| 42 | datefmt="%H:%M:%S") |
| 43 | handler.setFormatter(color_formatter) |
Klement Sekera | 6c7440c | 2016-12-23 09:16:39 +0100 | [diff] [blame] | 44 | handler.setLevel(log_level) |
| 45 | |
| 46 | global_logger = logging.getLogger() |
| 47 | global_logger.addHandler(handler) |
| 48 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 49 | scapy_logger = logging.getLogger("scapy.runtime") |
| 50 | scapy_logger.setLevel(logging.ERROR) |
| 51 | |
| 52 | |
juraj.linkes | dfb5f2a | 2018-11-09 11:58:54 +0100 | [diff] [blame] | 53 | def get_logger(name): |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 54 | logger = logging.getLogger(name) |
Klement Sekera | 6c7440c | 2016-12-23 09:16:39 +0100 | [diff] [blame] | 55 | logger.setLevel(logging.DEBUG) |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 56 | return logger |
| 57 | |
juraj.linkes | 184870a | 2018-07-16 14:22:01 +0200 | [diff] [blame] | 58 | |
| 59 | def get_parallel_logger(stream): |
Paul Vinciguerra | ea2450f | 2019-03-06 08:23:58 -0800 | [diff] [blame] | 60 | logger = logging.getLogger('parallel_logger_{!s}'.format(stream)) |
juraj.linkes | 184870a | 2018-07-16 14:22:01 +0200 | [diff] [blame] | 61 | logger.propagate = False |
juraj.linkes | 0219b8d | 2018-08-24 16:16:28 +0200 | [diff] [blame] | 62 | logger.setLevel(logging.DEBUG) |
juraj.linkes | 184870a | 2018-07-16 14:22:01 +0200 | [diff] [blame] | 63 | handler = logging.StreamHandler(stream) |
| 64 | handler.setFormatter(color_formatter) |
| 65 | handler.setLevel(log_level) |
| 66 | logger.addHandler(handler) |
| 67 | return logger |
| 68 | |
Klement Sekera | 277b89c | 2016-10-28 13:20:27 +0200 | [diff] [blame] | 69 | # Static variables to store color formatting strings. |
| 70 | # |
| 71 | # These variables (RED, GREEN, YELLOW and LPURPLE) are used to configure |
| 72 | # the color of the text to be printed in the terminal. Variable COLOR_RESET |
| 73 | # is used to revert the text color to the default one. |
| 74 | if hasattr(sys.stdout, 'isatty') and sys.stdout.isatty(): |
| 75 | RED = '\033[91m' |
| 76 | GREEN = '\033[92m' |
| 77 | YELLOW = '\033[93m' |
| 78 | LPURPLE = '\033[94m' |
| 79 | COLOR_RESET = '\033[0m' |
| 80 | else: |
| 81 | RED = '' |
| 82 | GREEN = '' |
| 83 | YELLOW = '' |
| 84 | LPURPLE = '' |
| 85 | COLOR_RESET = '' |