33 lines
907 B
Python
33 lines
907 B
Python
|
|
import logging
|
||
|
|
import sys
|
||
|
|
|
||
|
|
import structlog
|
||
|
|
|
||
|
|
from app.config import get_settings
|
||
|
|
|
||
|
|
|
||
|
|
def configure_logging() -> None:
|
||
|
|
settings = get_settings()
|
||
|
|
level = getattr(logging, settings.app_log_level.upper(), logging.INFO)
|
||
|
|
|
||
|
|
logging.basicConfig(
|
||
|
|
format="%(message)s",
|
||
|
|
stream=sys.stdout,
|
||
|
|
level=level,
|
||
|
|
)
|
||
|
|
|
||
|
|
structlog.configure(
|
||
|
|
processors=[
|
||
|
|
structlog.contextvars.merge_contextvars,
|
||
|
|
structlog.processors.add_log_level,
|
||
|
|
structlog.processors.TimeStamper(fmt="iso", utc=True),
|
||
|
|
structlog.processors.StackInfoRenderer(),
|
||
|
|
structlog.processors.format_exc_info,
|
||
|
|
structlog.processors.JSONRenderer(),
|
||
|
|
],
|
||
|
|
wrapper_class=structlog.make_filtering_bound_logger(level),
|
||
|
|
context_class=dict,
|
||
|
|
logger_factory=structlog.PrintLoggerFactory(),
|
||
|
|
cache_logger_on_first_use=True,
|
||
|
|
)
|