Coretex
formatter.py
1 # Copyright (C) 2023 Coretex LLC
2 
3 # This file is part of Coretex.ai
4 
5 # This program is free software: you can redistribute it and/or modify
6 # it under the terms of the GNU Affero General Public License as
7 # published by the Free Software Foundation, either version 3 of the
8 # License, or (at your option) any later version.
9 
10 # This program is distributed in the hope that it will be useful,
11 # but WITHOUT ANY WARRANTY; without even the implied warranty of
12 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 # GNU Affero General Public License for more details.
14 
15 # You should have received a copy of the GNU Affero General Public License
16 # along with this program. If not, see <https://www.gnu.org/licenses/>.
17 
18 from typing import Optional, Literal
19 from logging import Formatter, LogRecord
20 
21 import json
22 
23 from .severity import LogSeverity
24 from .utils import colorMessage
25 
26 
27 FormatStyle = Literal["%", "{", "$"]
28 
29 
30 class CTXFormatter(Formatter):
31 
32  def __init__(
33  self,
34  fmt: Optional[str] = None,
35  datefmt: Optional[str] = None,
36  style: FormatStyle = "%",
37  validate: bool = True,
38  color: bool = True,
39  jsonOutput: bool = True
40  ) -> None:
41 
42  super().__init__(fmt, datefmt, style, validate)
43 
44  self.color = color
45  self.jsonOutput = jsonOutput
46 
47  def format(self, record: LogRecord) -> str:
48  # INFO -> Info, ERROR -> Error, etc...
49  record.levelname = record.levelname.lower().capitalize()
50 
51  severity = LogSeverity.fromLevel(record.levelno)
52  formatted = super().format(record)
53 
54  if self.color:
55  formatted = colorMessage(severity, formatted)
56 
57  if self.jsonOutput:
58  return json.dumps({
59  "severity": severity.value,
60  "message": formatted + "\n"
61  })
62 
63  return formatted