2021-01-04 11:35:31 +03:00
|
|
|
import logging
|
|
|
|
import logging.config
|
|
|
|
import sys
|
|
|
|
|
|
|
|
from izihawa_utils.exceptions import BaseError
|
|
|
|
from izihawa_utils.file import mkdir_p
|
|
|
|
from library.logging.formatters import (
|
|
|
|
DefaultFormatter,
|
|
|
|
DefaultHttpFormatter,
|
|
|
|
)
|
|
|
|
from library.logging.handlers import QueueHandler
|
|
|
|
from prometheus_client import Counter
|
|
|
|
|
|
|
|
error_counter = Counter('errors_total', 'counter for error.log')
|
|
|
|
|
|
|
|
|
|
|
|
def configure_logging(config, make_path=True):
|
|
|
|
if config.get('application', {}).get('debug', False) or 'logging' not in config:
|
|
|
|
logging.basicConfig(stream=sys.stdout, level=logging.DEBUG)
|
|
|
|
else:
|
|
|
|
if make_path:
|
|
|
|
mkdir_p(config['log_path'])
|
|
|
|
logging.config.dictConfig(config['logging'])
|
|
|
|
|
|
|
|
|
|
|
|
def error_log(e, level=logging.ERROR, **fields):
|
|
|
|
level = getattr(e, 'level', level)
|
|
|
|
if level == logging.ERROR:
|
|
|
|
error_counter.inc()
|
|
|
|
if isinstance(e, BaseError):
|
|
|
|
e = e.as_internal_dict()
|
|
|
|
e.update(fields)
|
|
|
|
elif fields:
|
2021-04-12 20:47:21 +03:00
|
|
|
e = {'error': repr(e), **fields}
|
2021-01-04 11:35:31 +03:00
|
|
|
logging.getLogger('error').log(
|
|
|
|
msg=e,
|
|
|
|
level=level
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
'DefaultFormatter', 'DefaultHttpFormatter',
|
|
|
|
'QueueHandler', 'configure_logging', 'error_log',
|
|
|
|
]
|