88 lines
2.8 KiB
Python
88 lines
2.8 KiB
Python
|
## @package Log
|
||
|
# Module Log
|
||
|
import logging
|
||
|
import os
|
||
|
from logging.handlers import RotatingFileHandler
|
||
|
|
||
|
|
||
|
## Define constant color value for different level
|
||
|
class bcolors:
|
||
|
DEBUG = '\033[94m '
|
||
|
INFO = ' \033[95m '
|
||
|
WARNING = ' \033[93m '
|
||
|
FAIL = ' \033[91m '
|
||
|
ENDC = ' \033[0m '
|
||
|
|
||
|
|
||
|
## Define constant value for level utils
|
||
|
class lvl:
|
||
|
|
||
|
NOTSET = 0
|
||
|
DEBUG = 10
|
||
|
INFO = 20
|
||
|
WARNING = 30
|
||
|
FAIL = 40
|
||
|
CRITICAL = 50
|
||
|
|
||
|
|
||
|
## Filter for one level
|
||
|
class SingleLevelFilter(logging.Filter):
|
||
|
""""""
|
||
|
|
||
|
## Constructor
|
||
|
# @param passlevel level to filter
|
||
|
# @param reject true on reject state
|
||
|
def __init__(self, passlevel, reject):
|
||
|
self.passlevel = passlevel
|
||
|
self.reject = reject
|
||
|
|
||
|
def filter(self, record):
|
||
|
if self.reject:
|
||
|
return (record.levelno != self.passlevel)
|
||
|
else:
|
||
|
return (record.levelno == self.passlevel)
|
||
|
|
||
|
## Log Manager
|
||
|
class Log(object):
|
||
|
## Define 3 differents utils :
|
||
|
# activity.log -> all activity
|
||
|
# warning.log -> only warning
|
||
|
# error.log -> error
|
||
|
# Write all message on terminal too
|
||
|
def __init__(self,directory):
|
||
|
if not os.path.exists(directory):
|
||
|
os.makedirs(directory)
|
||
|
self.logger = logging.getLogger()
|
||
|
self.logger.setLevel(logging.DEBUG)
|
||
|
formatter = logging.Formatter('%(asctime)-15s :: %(levelname)s :: %(message)s')
|
||
|
file_handler = RotatingFileHandler(directory+'/activity.log', 'a', 1000000, 1)
|
||
|
file_handler.setLevel(logging.DEBUG)
|
||
|
file_handler.setFormatter(formatter)
|
||
|
self.logger.addHandler(file_handler)
|
||
|
file_handler_warning = RotatingFileHandler(directory+'/warning.log', 'a', 1000000, 1)
|
||
|
f1 = SingleLevelFilter(logging.WARNING, False)
|
||
|
file_handler_warning.addFilter(f1)
|
||
|
file_handler_warning.setFormatter(formatter)
|
||
|
self.logger.addHandler(file_handler_warning)
|
||
|
file_handler_error = RotatingFileHandler(directory+'/error.log', 'a', 1000000, 1)
|
||
|
file_handler_error.setLevel(logging.ERROR)
|
||
|
file_handler_error.setFormatter(formatter)
|
||
|
self.logger.addHandler(file_handler_error)
|
||
|
steam_handler = logging.StreamHandler()
|
||
|
steam_handler.setLevel(logging.NOTSET)
|
||
|
self.logger.addHandler(steam_handler)
|
||
|
|
||
|
|
||
|
## Add color and write in log with an define level
|
||
|
# @param pMsg message to write in log
|
||
|
# @param pLvl level of log message
|
||
|
def printL(self, pMsg, pLvl):
|
||
|
if pLvl == lvl.DEBUG:
|
||
|
pMsg = bcolors.DEBUG + str(pMsg) + bcolors.ENDC
|
||
|
elif pLvl == lvl.INFO:
|
||
|
pMsg = bcolors.INFO + str(pMsg) + bcolors.ENDC
|
||
|
elif pLvl == lvl.WARNING:
|
||
|
pMsg = bcolors.WARNING + str(pMsg) + bcolors.ENDC
|
||
|
elif pLvl == lvl.FAIL:
|
||
|
pMsg = bcolors.FAIL + str(pMsg) + bcolors.ENDC
|
||
|
self.logger.log(pLvl, pMsg)
|