""" Package `ovdashboard_api`: Contains the API powering the "OVDashboard" application. This file: Sets up logging. """ import logging.config from pydantic import BaseModel class LogConfig(BaseModel): """ Logging configuration to be set for the server. https://stackoverflow.com/a/67937084 """ LOG_FORMAT: str = "%(levelprefix)s [%(asctime)s] %(name)s: %(message)s" LOG_LEVEL: str = "DEBUG" # Logging config version = 1 disable_existing_loggers = False formatters = { "default": { "()": "uvicorn.logging.DefaultFormatter", "fmt": LOG_FORMAT, "datefmt": "%Y-%m-%d %H:%M:%S", }, } handlers = { "default": { "formatter": "default", "class": "logging.StreamHandler", "stream": "ext://sys.stderr", }, } loggers = { "ovdashboard_api": {"handlers": ["default"], "level": LOG_LEVEL}, } logging.config.dictConfig(LogConfig().dict())