-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathloggers.py
More file actions
109 lines (79 loc) · 2.67 KB
/
loggers.py
File metadata and controls
109 lines (79 loc) · 2.67 KB
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
import logging
import json
from collections import OrderedDict
class CSVFileHandler(logging.FileHandler):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
# column names are defined in StateMachine class
self.columns = [
"clock_time",
"object_type",
"uuid",
"itinerary_id",
"from_state",
"to_state",
"lon",
"lat",
"details",
]
self.header = ";".join(self.columns)
def emit(self, record):
if not isinstance(record.msg, str):
record.msg = self.format_message(record.msg)
super().emit(record)
def format_message(self, state_info: OrderedDict) -> str:
strings = []
for column in self.columns:
item = state_info.get(column)
try:
if item is None:
item = ""
elif isinstance(item, dict):
item = json.dumps(item, separators=(",", ":"))
else:
item = str(item)
# catche error json.encoder.JSONEncoder
except TypeError:
item = str(item)
strings.append(item)
msg = ";".join(strings)
return msg
class InMemoryLogHandler(logging.NullHandler):
def __init__(self, *args, **kwargs):
super().__init__(*args, **kwargs)
self.logs = []
def handle(self, record):
self.logs.append(dict(record.msg))
super().handle(record)
def get_simobility_logger(handler=None):
logger = logging.getLogger("simobility.state_changes")
if handler:
handler.setLevel(logging.INFO)
formatter = logging.Formatter("%(message)s")
handler.setFormatter(formatter)
logger.addHandler(handler)
return logger
def configure_csv_logger(file_name):
disable_loggers()
handler = CSVFileHandler(file_name, "w")
logger = get_simobility_logger(handler)
logger.info(handler.header)
return logger
def configure_root_logger(
level=logging.DEBUG, format="%(name)s %(asctime)s %(levelname)s: %(message)s"
):
class RootFilter(logging.Filter):
def filter(self, record):
return record.name == "root"
logger = logging.getLogger()
logger.setLevel(level)
ch = logging.StreamHandler()
formatter = logging.Formatter(format)
ch.setFormatter(formatter)
ch.addFilter(RootFilter())
logger.addHandler(ch)
def disable_loggers():
log = logging.getLogger("urllib3.connectionpool")
log.setLevel(logging.CRITICAL)
log = logging.getLogger("transitions.core")
log.setLevel(logging.CRITICAL)