open-webui/backend/open_webui/apps/webui/routers/models.py

113 lines
2.8 KiB
Python
Raw Normal View History

2024-08-27 22:10:27 +00:00
from typing import Optional
2024-05-24 07:26:00 +00:00
from open_webui.apps.webui.models.models import (
ModelForm,
ModelModel,
ModelResponse,
Models,
)
from open_webui.constants import ERROR_MESSAGES
2024-08-27 22:10:27 +00:00
from fastapi import APIRouter, Depends, HTTPException, Request, status
from open_webui.utils.utils import get_admin_user, get_verified_user
2024-05-24 07:26:00 +00:00
router = APIRouter()
###########################
2024-05-24 09:17:48 +00:00
# getModels
2024-05-24 07:26:00 +00:00
###########################
2024-08-14 12:46:31 +00:00
@router.get("/", response_model=list[ModelResponse])
async def get_models(user=Depends(get_verified_user)):
return Models.get_all_models()
2024-05-24 07:26:00 +00:00
############################
# AddNewModel
############################
@router.post("/add", response_model=Optional[ModelModel])
2024-05-25 05:21:57 +00:00
async def add_new_model(
request: Request,
form_data: ModelForm,
user=Depends(get_admin_user),
2024-05-25 05:21:57 +00:00
):
if form_data.id in request.app.state.MODELS:
2024-05-24 07:26:00 +00:00
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
2024-05-25 05:21:57 +00:00
detail=ERROR_MESSAGES.MODEL_ID_TAKEN,
2024-05-24 07:26:00 +00:00
)
2024-05-25 05:21:57 +00:00
else:
model = Models.insert_new_model(form_data, user.id)
2024-05-25 05:21:57 +00:00
if model:
return model
else:
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail=ERROR_MESSAGES.DEFAULT(),
)
2024-05-24 07:26:00 +00:00
############################
# GetModelById
############################
@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)
2024-05-24 07:26:00 +00:00
if model:
return model
else:
raise HTTPException(
status_code=status.HTTP_401_UNAUTHORIZED,
detail=ERROR_MESSAGES.NOT_FOUND,
)
############################
# UpdateModelById
############################
2024-05-25 20:48:45 +00:00
@router.post("/update", response_model=Optional[ModelModel])
2024-05-24 07:26:00 +00:00
async def update_model_by_id(
request: Request,
id: str,
form_data: ModelForm,
user=Depends(get_admin_user),
2024-05-24 07:26:00 +00:00
):
model = Models.get_model_by_id(id)
2024-05-24 07:26:00 +00:00
if model:
model = Models.update_model_by_id(id, form_data)
2024-05-24 07:26:00 +00:00
return model
else:
2024-05-25 01:26:36 +00:00
if form_data.id in request.app.state.MODELS:
model = Models.insert_new_model(form_data, user.id)
2024-05-25 01:26:36 +00:00
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(),
)
2024-05-24 07:26:00 +00:00
############################
# DeleteModelById
############################
2024-05-25 20:48:45 +00:00
@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)
2024-05-24 07:26:00 +00:00
return result