30 lines
934 B
Python
30 lines
934 B
Python
import json
|
|
import logging
|
|
import sys
|
|
from datetime import datetime, timezone
|
|
|
|
|
|
class JsonFormatter(logging.Formatter):
|
|
def format(self, record: logging.LogRecord) -> str:
|
|
payload = {
|
|
"timestamp": datetime.now(timezone.utc).isoformat(),
|
|
"level": record.levelname.lower(),
|
|
"logger": record.name,
|
|
"message": record.getMessage(),
|
|
}
|
|
extras = getattr(record, "extra", None)
|
|
if isinstance(extras, dict):
|
|
payload.update(extras)
|
|
if record.exc_info:
|
|
payload["exc_info"] = self.formatException(record.exc_info)
|
|
return json.dumps(payload, ensure_ascii=True)
|
|
|
|
|
|
def configure_logging(level: str = "INFO") -> None:
|
|
root = logging.getLogger()
|
|
root.setLevel(level.upper())
|
|
handler = logging.StreamHandler(sys.stdout)
|
|
handler.setFormatter(JsonFormatter())
|
|
root.handlers.clear()
|
|
root.addHandler(handler)
|