mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-04 17:35:39 +00:00
44 lines
1.4 KiB
Python
44 lines
1.4 KiB
Python
|
import os
|
||
|
import logging
|
||
|
|
||
|
class logger(object):
|
||
|
def __init__(self, name, level, logfile):
|
||
|
self.name = name
|
||
|
self.level = level
|
||
|
self.logfile = logfile
|
||
|
|
||
|
def config(self):
|
||
|
# define logger and set logging level
|
||
|
logger = logging.getLogger()
|
||
|
|
||
|
if self.level == 'CRITICAL':
|
||
|
level = logging.CRITICAL
|
||
|
elif self.level == 'ERROR':
|
||
|
level = logging.ERROR
|
||
|
elif self.level == 'WARNING':
|
||
|
level = logging.WARNING
|
||
|
elif self.level == 'DEBUG':
|
||
|
level = logging.DEBUG
|
||
|
else:
|
||
|
level = logging.INFO
|
||
|
|
||
|
logger.setLevel(level)
|
||
|
|
||
|
# set request requests module log level
|
||
|
logging.getLogger("requests").setLevel(logging.CRITICAL)
|
||
|
|
||
|
# define handler to log into file
|
||
|
file_log_handler = logging.FileHandler(self.logfile)
|
||
|
logger.addHandler(file_log_handler)
|
||
|
|
||
|
# define handler to log into console
|
||
|
stderr_log_handler = logging.StreamHandler()
|
||
|
logger.addHandler(stderr_log_handler)
|
||
|
|
||
|
# define logging format for file and console
|
||
|
file_formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
|
||
|
console_formatter = logging.Formatter('[%(levelname)s] %(message)s')
|
||
|
file_log_handler.setFormatter(file_formatter)
|
||
|
stderr_log_handler.setFormatter(console_formatter)
|
||
|
|
||
|
return logging.getLogger(self.name)
|