-
-
Notifications
You must be signed in to change notification settings - Fork 82
Expand file tree
/
Copy pathlogging.py
More file actions
22 lines (18 loc) · 653 Bytes
/
logging.py
File metadata and controls
22 lines (18 loc) · 653 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
import logging
from rich.console import Console
from rich.logging import RichHandler
def setup_logging(terminal_width: int | None = None, level: int = logging.INFO) -> None:
logger = logging.getLogger("fastapi_cli")
console = Console(width=terminal_width) if terminal_width else None
rich_handler = RichHandler(
show_time=False,
rich_tracebacks=True,
tracebacks_show_locals=True,
markup=True,
show_path=False,
console=console,
)
rich_handler.setFormatter(logging.Formatter("%(message)s"))
logger.addHandler(rich_handler)
logger.setLevel(level)
logger.propagate = False