Source code for sas.logger_config
from __future__ import print_function
import logging
import logging.config
import os
import sys
import os.path
import pkg_resources
from sas import get_custom_config
'''
Module that manages the global logging
'''
[docs]class SetupLogger(object):
'''
Called at the beginning of run.py or sasview.py
'''
[docs] def __init__(self, logger_name):
self._find_config_file()
self.name = logger_name
[docs] def config_production(self):
logger = logging.getLogger(self.name)
if not logger.root.handlers:
self._read_config_file()
logging.captureWarnings(True)
logger = logging.getLogger(self.name)
logging.getLogger('matplotlib').setLevel(logging.WARN)
return logger
[docs] def config_development(self):
'''
'''
self._read_config_file()
logger = logging.getLogger(self.name)
self._update_all_logs_to_debug(logger)
logging.captureWarnings(True)
self._disable_debug_from_config()
logging.getLogger('matplotlib').setLevel(logging.WARN)
return logger
[docs] def _disable_debug_from_config(self):
'''disable DEBUG logs as per user configuration (DEBUG logs disabled by default)'''
disable_debug = True
custom_config = get_custom_config()
if hasattr(custom_config, "FILTER_DEBUG_LOGS"):
if type(custom_config.FILTER_DEBUG_LOGS) is bool:
disable_debug = custom_config.FILTER_DEBUG_LOGS
else:
logging.warning("FILTER_DEBUG_LOGS has invalid value in custom_config.py")
if disable_debug:
# logging.info("Note: DEBUG logs are disabled.")
logging.disable(logging.DEBUG)
[docs] def _read_config_file(self):
if self.config_file is not None:
logging.config.fileConfig(self.config_file)
[docs] def _update_all_logs_to_debug(self, logger):
'''
This updates all loggers and respective handlers to DEBUG
'''
for handler in logger.handlers or logger.parent.handlers:
handler.setLevel(logging.DEBUG)
for name, _ in logging.Logger.manager.loggerDict.items():
logging.getLogger(name).setLevel(logging.DEBUG)
[docs] def _find_config_file(self, filename="logging.ini"):
'''
The config file is in:
Debug ./sasview/
Packaging: sas/sasview/
Packaging / production does not work well with absolute paths
thus the multiple paths below
'''
places_to_look_for_conf_file = [
os.path.join(os.path.abspath(os.path.dirname(__file__)), filename),
filename,
os.path.join("sas", "sasview", filename),
os.path.join(os.getcwd(), "sas", "sasview", filename),
os.path.join(os.path.dirname(os.path.realpath(sys.argv[0])), filename) #For OSX app
]
# To avoid the exception in OSx
# NotImplementedError: resource_filename() only supported for .egg, not .zip
try:
places_to_look_for_conf_file.append(
pkg_resources.resource_filename(__name__, filename))
except NotImplementedError:
pass
for filepath in places_to_look_for_conf_file:
if os.path.exists(filepath):
self.config_file = filepath
return
print("ERROR: Logging.ini not found...")
self.config_file = None