Spaces:
Paused
Paused
| from __future__ import annotations | |
| import logging | |
| import os | |
| import sys | |
| DEFAULT_LOG_LEVEL = os.getenv("APP_LOG_LEVEL", "INFO").upper() | |
| LOG_FORMAT = "%(asctime)s | %(levelname)s | %(name)s | %(message)s" | |
| def configure_logging(level: str | None = None) -> None: | |
| resolved_level_name = (level or DEFAULT_LOG_LEVEL).upper() | |
| resolved_level = getattr(logging, resolved_level_name, logging.INFO) | |
| formatter = logging.Formatter(LOG_FORMAT) | |
| root_logger = logging.getLogger() | |
| if not root_logger.handlers: | |
| handler = logging.StreamHandler(sys.stdout) | |
| handler.setFormatter(formatter) | |
| root_logger.addHandler(handler) | |
| else: | |
| for handler in root_logger.handlers: | |
| handler.setFormatter(formatter) | |
| root_logger.setLevel(resolved_level) | |
| logging.captureWarnings(True) | |
| for logger_name in ("gunicorn.error", "gunicorn.access", "werkzeug"): | |
| logging.getLogger(logger_name).setLevel(resolved_level) | |
| def get_logger(name: str) -> logging.Logger: | |
| return logging.getLogger(name) | |