2018-05-18 00:24:50 +08:00
|
|
|
import os
|
|
|
|
import json
|
|
|
|
import logging.config
|
|
|
|
|
|
|
|
|
2018-05-30 23:30:56 +08:00
|
|
|
__author__ = 'Maor.Rayzin'
|
|
|
|
|
|
|
|
|
2018-05-18 00:24:50 +08:00
|
|
|
def json_setup_logging(default_path='logging.json', default_level=logging.INFO, env_key='LOG_CFG'):
|
|
|
|
"""
|
|
|
|
Setup the logging configuration
|
|
|
|
:param default_path: the default log configuration file path
|
|
|
|
:param default_level: Default level to log from
|
|
|
|
:param env_key: SYS ENV key to use for external configuration file path
|
|
|
|
:return:
|
|
|
|
"""
|
|
|
|
path = default_path
|
|
|
|
value = os.getenv(env_key, None)
|
|
|
|
if value:
|
|
|
|
path = value
|
|
|
|
if os.path.exists(path):
|
|
|
|
with open(path, 'rt') as f:
|
|
|
|
config = json.load(f)
|
|
|
|
logging.config.dictConfig(config)
|
|
|
|
else:
|
|
|
|
logging.basicConfig(level=default_level)
|