InvokeAI/invokeai/app/api/routers/app_info.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

106 lines
3.3 KiB
Python
Raw Normal View History

import typing
from enum import Enum
2023-09-01 16:48:18 +00:00
from pathlib import Path
from fastapi import Body
2023-07-08 09:31:17 +00:00
from fastapi.routing import APIRouter
from pydantic import BaseModel, Field
2023-07-08 09:31:17 +00:00
2023-09-01 16:48:18 +00:00
from invokeai.app.invocations.upscale import ESRGAN_MODELS
from invokeai.backend.image_util.invisible_watermark import InvisibleWatermark
from invokeai.backend.image_util.patchmatch import PatchMatch
from invokeai.backend.image_util.safety_checker import SafetyChecker
2023-09-01 16:48:18 +00:00
from invokeai.backend.util.logging import logging
2023-07-08 09:31:17 +00:00
from invokeai.version import __version__
from ..dependencies import ApiDependencies
2023-07-27 14:54:01 +00:00
class LogLevel(int, Enum):
NotSet = logging.NOTSET
Debug = logging.DEBUG
Info = logging.INFO
Warning = logging.WARNING
Error = logging.ERROR
Critical = logging.CRITICAL
2023-07-27 14:54:01 +00:00
class Upscaler(BaseModel):
upscaling_method: str = Field(description="Name of upscaling method")
upscaling_models: list[str] = Field(description="List of upscaling models for this method")
2023-07-27 14:54:01 +00:00
app_router = APIRouter(prefix="/v1/app", tags=["app"])
2023-07-08 09:31:17 +00:00
class AppVersion(BaseModel):
"""App Version Response"""
version: str = Field(description="App version")
2023-07-08 09:31:17 +00:00
2023-07-12 15:54:42 +00:00
class AppConfig(BaseModel):
"""App Config Response"""
infill_methods: list[str] = Field(description="List of available infill methods")
upscaling_methods: list[Upscaler] = Field(description="List of upscaling methods")
nsfw_methods: list[str] = Field(description="List of NSFW checking methods")
watermarking_methods: list[str] = Field(description="List of invisible watermark methods")
2023-07-12 15:54:42 +00:00
2023-07-08 09:31:17 +00:00
@app_router.get("/version", operation_id="app_version", status_code=200, response_model=AppVersion)
2023-07-08 09:31:17 +00:00
async def get_version() -> AppVersion:
return AppVersion(version=__version__)
2023-07-12 15:54:42 +00:00
@app_router.get("/config", operation_id="get_config", status_code=200, response_model=AppConfig)
2023-07-12 15:54:42 +00:00
async def get_config() -> AppConfig:
2023-09-01 16:48:18 +00:00
infill_methods = ["tile", "lama", "cv2"]
if PatchMatch.patchmatch_available():
infill_methods.append("patchmatch")
upscaling_models = []
for model in typing.get_args(ESRGAN_MODELS):
upscaling_models.append(str(Path(model).stem))
upscaler = Upscaler(upscaling_method="esrgan", upscaling_models=upscaling_models)
2023-07-27 14:54:01 +00:00
nsfw_methods = []
if SafetyChecker.safety_checker_available():
nsfw_methods.append("nsfw_checker")
watermarking_methods = []
if InvisibleWatermark.invisible_watermark_available():
watermarking_methods.append("invisible_watermark")
2023-07-27 14:54:01 +00:00
return AppConfig(
infill_methods=infill_methods,
upscaling_methods=[upscaler],
nsfw_methods=nsfw_methods,
watermarking_methods=watermarking_methods,
)
2023-07-27 14:54:01 +00:00
@app_router.get(
"/logging",
operation_id="get_log_level",
responses={200: {"description": "The operation was successful"}},
response_model=LogLevel,
)
async def get_log_level() -> LogLevel:
"""Returns the log level"""
return LogLevel(ApiDependencies.invoker.services.logger.level)
2023-07-27 14:54:01 +00:00
@app_router.post(
"/logging",
operation_id="set_log_level",
responses={200: {"description": "The operation was successful"}},
response_model=LogLevel,
)
async def set_log_level(
level: LogLevel = Body(description="New log verbosity level"),
) -> LogLevel:
"""Sets the log verbosity level"""
ApiDependencies.invoker.services.logger.setLevel(level)
return LogLevel(ApiDependencies.invoker.services.logger.level)