2023-08-30 10:22:01 +02:00
|
|
|
import logging
|
2023-08-25 06:28:51 +02:00
|
|
|
import os
|
2023-06-25 05:18:09 +02:00
|
|
|
from pathlib import Path
|
|
|
|
|
2023-08-30 10:22:01 +02:00
|
|
|
import starlette
|
2023-06-18 05:49:19 +02:00
|
|
|
from pydantic import BaseSettings
|
2023-08-30 10:22:01 +02:00
|
|
|
from rich.console import Console
|
|
|
|
from rich.logging import RichHandler
|
2023-06-18 05:49:19 +02:00
|
|
|
|
2023-06-25 05:18:09 +02:00
|
|
|
from .schemas import ModelType
|
|
|
|
|
|
|
|
|
2023-06-18 05:49:19 +02:00
|
|
|
class Settings(BaseSettings):
|
|
|
|
cache_folder: str = "/cache"
|
2023-08-21 01:24:14 +02:00
|
|
|
eager_startup: bool = False
|
2023-07-11 19:01:21 +02:00
|
|
|
model_ttl: int = 0
|
2023-06-18 05:49:19 +02:00
|
|
|
host: str = "0.0.0.0"
|
|
|
|
port: int = 3003
|
|
|
|
workers: int = 1
|
2023-06-28 01:21:33 +02:00
|
|
|
test_full: bool = False
|
2023-08-25 06:28:51 +02:00
|
|
|
request_threads: int = os.cpu_count() or 4
|
|
|
|
model_inter_op_threads: int = 1
|
|
|
|
model_intra_op_threads: int = 2
|
2023-06-18 05:49:19 +02:00
|
|
|
|
2023-08-06 04:45:13 +02:00
|
|
|
class Config:
|
2023-06-25 05:18:09 +02:00
|
|
|
env_prefix = "MACHINE_LEARNING_"
|
2023-06-18 05:49:19 +02:00
|
|
|
case_sensitive = False
|
|
|
|
|
|
|
|
|
2023-08-30 10:22:01 +02:00
|
|
|
class LogSettings(BaseSettings):
|
|
|
|
log_level: str = "info"
|
|
|
|
no_color: bool = False
|
|
|
|
|
|
|
|
class Config:
|
|
|
|
case_sensitive = False
|
|
|
|
|
|
|
|
|
2023-08-25 06:28:51 +02:00
|
|
|
_clean_name = str.maketrans(":\\/", "___", ".")
|
|
|
|
|
|
|
|
|
2023-06-25 05:18:09 +02:00
|
|
|
def get_cache_dir(model_name: str, model_type: ModelType) -> Path:
|
2023-08-25 06:28:51 +02:00
|
|
|
return Path(settings.cache_folder) / model_type.value / model_name.translate(_clean_name)
|
2023-06-25 05:18:09 +02:00
|
|
|
|
|
|
|
|
2023-08-30 10:22:01 +02:00
|
|
|
LOG_LEVELS: dict[str, int] = {
|
|
|
|
"critical": logging.ERROR,
|
|
|
|
"error": logging.ERROR,
|
|
|
|
"warning": logging.WARNING,
|
|
|
|
"warn": logging.WARNING,
|
|
|
|
"info": logging.INFO,
|
|
|
|
"log": logging.INFO,
|
|
|
|
"debug": logging.DEBUG,
|
|
|
|
"verbose": logging.DEBUG,
|
|
|
|
}
|
|
|
|
|
2023-06-18 05:49:19 +02:00
|
|
|
settings = Settings()
|
2023-08-30 10:22:01 +02:00
|
|
|
log_settings = LogSettings()
|
|
|
|
|
|
|
|
console = Console(color_system="standard", no_color=log_settings.no_color)
|
|
|
|
logging.basicConfig(
|
|
|
|
format="%(message)s",
|
|
|
|
handlers=[
|
|
|
|
RichHandler(show_path=False, omit_repeated_times=False, console=console, tracebacks_suppress=[starlette])
|
|
|
|
],
|
|
|
|
)
|
|
|
|
log = logging.getLogger("uvicorn")
|
|
|
|
log.setLevel(LOG_LEVELS.get(log_settings.log_level.lower(), logging.INFO))
|