|
from fastapi import Depends, FastAPI, HTTPException, status, Request |
|
from datetime import datetime, timedelta |
|
from typing import List, Union, Optional |
|
|
|
from fastapi import APIRouter |
|
from pydantic import BaseModel |
|
import json |
|
|
|
from apps.webui.models.models import Models, ModelModel, ModelForm, ModelResponse |
|
|
|
from utils.utils import get_verified_user, get_admin_user |
|
from constants import ERROR_MESSAGES |
|
|
|
router = APIRouter() |
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.get("/", response_model=List[ModelResponse]) |
|
async def get_models(user=Depends(get_verified_user)): |
|
return Models.get_all_models() |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.post("/add", response_model=Optional[ModelModel]) |
|
async def add_new_model( |
|
request: Request, |
|
form_data: ModelForm, |
|
user=Depends(get_admin_user), |
|
): |
|
if form_data.id in request.app.state.MODELS: |
|
raise HTTPException( |
|
status_code=status.HTTP_401_UNAUTHORIZED, |
|
detail=ERROR_MESSAGES.MODEL_ID_TAKEN, |
|
) |
|
else: |
|
model = Models.insert_new_model(form_data, user.id) |
|
|
|
if model: |
|
return model |
|
else: |
|
raise HTTPException( |
|
status_code=status.HTTP_401_UNAUTHORIZED, |
|
detail=ERROR_MESSAGES.DEFAULT(), |
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.get("/", response_model=Optional[ModelModel]) |
|
async def get_model_by_id(id: str, user=Depends(get_verified_user)): |
|
model = Models.get_model_by_id(id) |
|
|
|
if model: |
|
return model |
|
else: |
|
raise HTTPException( |
|
status_code=status.HTTP_401_UNAUTHORIZED, |
|
detail=ERROR_MESSAGES.NOT_FOUND, |
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.post("/update", response_model=Optional[ModelModel]) |
|
async def update_model_by_id( |
|
request: Request, |
|
id: str, |
|
form_data: ModelForm, |
|
user=Depends(get_admin_user), |
|
): |
|
model = Models.get_model_by_id(id) |
|
if model: |
|
model = Models.update_model_by_id(id, form_data) |
|
return model |
|
else: |
|
if form_data.id in request.app.state.MODELS: |
|
model = Models.insert_new_model(form_data, user.id) |
|
if model: |
|
return model |
|
else: |
|
raise HTTPException( |
|
status_code=status.HTTP_401_UNAUTHORIZED, |
|
detail=ERROR_MESSAGES.DEFAULT(), |
|
) |
|
else: |
|
raise HTTPException( |
|
status_code=status.HTTP_401_UNAUTHORIZED, |
|
detail=ERROR_MESSAGES.DEFAULT(), |
|
) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@router.delete("/delete", response_model=bool) |
|
async def delete_model_by_id(id: str, user=Depends(get_admin_user)): |
|
result = Models.delete_model_by_id(id) |
|
return result |
|
|