2024-10-03 15:33:53 +03:00
|
|
|
from pydantic import Field, ValidationInfo, model_validator
|
|
|
|
|
from typing_extensions import Self
|
2024-09-28 22:21:42 +03:00
|
|
|
|
2025-06-13 17:43:38 +03:00
|
|
|
from frigate.log import LogLevel, apply_log_levels
|
2024-09-28 22:21:42 +03:00
|
|
|
|
2025-06-13 17:43:38 +03:00
|
|
|
from .base import FrigateBaseModel
|
2024-09-28 22:21:42 +03:00
|
|
|
|
2025-06-13 17:43:38 +03:00
|
|
|
__all__ = ["LoggerConfig"]
|
2024-09-28 22:21:42 +03:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class LoggerConfig(FrigateBaseModel):
|
|
|
|
|
default: LogLevel = Field(default=LogLevel.info, title="Default logging level.")
|
|
|
|
|
logs: dict[str, LogLevel] = Field(
|
|
|
|
|
default_factory=dict, title="Log level for specified processes."
|
|
|
|
|
)
|
2024-10-03 15:33:53 +03:00
|
|
|
|
|
|
|
|
@model_validator(mode="after")
|
|
|
|
|
def post_validation(self, info: ValidationInfo) -> Self:
|
|
|
|
|
if isinstance(info.context, dict) and info.context.get("install", False):
|
2025-06-13 17:43:38 +03:00
|
|
|
apply_log_levels(self.default.value.upper(), self.logs)
|
2025-03-11 15:57:00 +03:00
|
|
|
|
|
|
|
|
return self
|