36 lines
1.1 KiB
Python
36 lines
1.1 KiB
Python
import json
|
|
import logging
|
|
import sys
|
|
from datetime import UTC, datetime
|
|
|
|
|
|
class JsonFormatter(logging.Formatter):
|
|
"""Emit structured log records for the atlasbot services."""
|
|
|
|
def format(self, record: logging.LogRecord) -> str:
|
|
"""Render a log record as JSON for downstream ingestion."""
|
|
|
|
payload = {
|
|
"timestamp": datetime.now(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:
|
|
"""Install JSON logging on the process root logger."""
|
|
|
|
root = logging.getLogger()
|
|
root.setLevel(level.upper())
|
|
handler = logging.StreamHandler(sys.stdout)
|
|
handler.setFormatter(JsonFormatter())
|
|
root.handlers.clear()
|
|
root.addHandler(handler)
|