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)