-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathlogger.py
31 lines (26 loc) · 1023 Bytes
/
logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
import logging
import sys
from pythonjsonlogger import jsonlogger
import os
from datetime import datetime
logging_level = os.getenv("LOG_LEVEL") or 'INFO'
class CustomJsonFormatter(jsonlogger.JsonFormatter):
def add_fields(self, log_record, record, message_dict):
super(CustomJsonFormatter, self).add_fields(
log_record, record, message_dict)
if not log_record.get('timestamp'):
log_record['timestamp'] = datetime.fromtimestamp(record.created)
if log_record.get('severity'):
log_record['severity'] = log_record['severity'].upper()
else:
log_record['severity'] = record.levelname
def getJSONLogger(name):
logger = logging.getLogger(name)
handler = logging.StreamHandler(sys.stdout)
formatter = CustomJsonFormatter(
'%(timestamp)s %(severity)s %(name)s %(message)s')
handler.setFormatter(formatter)
logger.addHandler(handler)
logger.setLevel(logging_level)
logger.propagate = False
return logger