atlasbot/atlasbot/logging.py

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)