File size: 1,445 Bytes
393d3de
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
import logging
from termcolor import colored


class LiberoColorFormatter(logging.Formatter):
    """This color format is for logging user's project wise information"""

    format_str = "[Project %(levelname)s] "
    debug_message_str = "%(message)s (%(filename)s:%(lineno)d)"
    message_str = "%(message)s"
    FORMATS = {
        logging.DEBUG: format_str + debug_message_str,
        logging.INFO: message_str,
        logging.WARNING: colored(format_str, "yellow", attrs=["bold"]) + message_str,
        logging.ERROR: colored(format_str, "red", attrs=["bold"]) + message_str,
        logging.CRITICAL: colored(format_str, "red", attrs=["bold", "reverse"])
        + message_str,
    }

    def format(self, record):
        log_fmt = self.FORMATS.get(record.levelno)
        formatter = logging.Formatter(log_fmt)
        return formatter.format(record)


class LiberoDefaultLogger:
    def __init__(self, logger_config_path, project_name="libero"):
        config = YamlConfig(logger_config_path).as_easydict()
        config["loggers"][project_name] = config["loggers"]["project"]
        os.makedirs("logs", exist_ok=True)
        logging.config.dictConfig(config)


ProjectDefaultLogger(logger_config_path, project_name)


def get_project_logger(project_name="libero", logger_config_path=None):
    """This function returns a logger that follows the deoxys convention"""
    logger = logging.getLogger(project_name)
    return logger