|
@@ -95,7 +95,7 @@ async def get_user_chat_list_by_user_id(
|
|
|
async def create_new_chat(form_data: ChatForm, user=Depends(get_verified_user)):
|
|
|
try:
|
|
|
chat = Chats.insert_new_chat(user.id, form_data)
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
except Exception as e:
|
|
|
log.exception(e)
|
|
|
raise HTTPException(
|
|
@@ -111,7 +111,7 @@ async def create_new_chat(form_data: ChatForm, user=Depends(get_verified_user)):
|
|
|
@router.get("/all", response_model=list[ChatResponse])
|
|
|
async def get_user_chats(user=Depends(get_verified_user)):
|
|
|
return [
|
|
|
- ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ ChatResponse(**chat.model_dump())
|
|
|
for chat in Chats.get_chats_by_user_id(user.id)
|
|
|
]
|
|
|
|
|
@@ -124,7 +124,7 @@ async def get_user_chats(user=Depends(get_verified_user)):
|
|
|
@router.get("/all/archived", response_model=list[ChatResponse])
|
|
|
async def get_user_archived_chats(user=Depends(get_verified_user)):
|
|
|
return [
|
|
|
- ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ ChatResponse(**chat.model_dump())
|
|
|
for chat in Chats.get_archived_chats_by_user_id(user.id)
|
|
|
]
|
|
|
|
|
@@ -141,10 +141,7 @@ async def get_all_user_chats_in_db(user=Depends(get_admin_user)):
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED,
|
|
|
detail=ERROR_MESSAGES.ACCESS_PROHIBITED,
|
|
|
)
|
|
|
- return [
|
|
|
- ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
- for chat in Chats.get_chats()
|
|
|
- ]
|
|
|
+ return [ChatResponse(**chat.model_dump()) for chat in Chats.get_chats()]
|
|
|
|
|
|
|
|
|
############################
|
|
@@ -187,7 +184,8 @@ async def get_shared_chat_by_id(share_id: str, user=Depends(get_verified_user)):
|
|
|
chat = Chats.get_chat_by_id(share_id)
|
|
|
|
|
|
if chat:
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
+
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED, detail=ERROR_MESSAGES.NOT_FOUND
|
|
@@ -251,7 +249,8 @@ async def get_chat_by_id(id: str, user=Depends(get_verified_user)):
|
|
|
chat = Chats.get_chat_by_id_and_user_id(id, user.id)
|
|
|
|
|
|
if chat:
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
+
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED, detail=ERROR_MESSAGES.NOT_FOUND
|
|
@@ -269,10 +268,9 @@ async def update_chat_by_id(
|
|
|
):
|
|
|
chat = Chats.get_chat_by_id_and_user_id(id, user.id)
|
|
|
if chat:
|
|
|
- updated_chat = {**json.loads(chat.chat), **form_data.chat}
|
|
|
-
|
|
|
+ updated_chat = {**chat.chat, **form_data.chat}
|
|
|
chat = Chats.update_chat_by_id(id, updated_chat)
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED,
|
|
@@ -312,16 +310,15 @@ async def delete_chat_by_id(request: Request, id: str, user=Depends(get_verified
|
|
|
async def clone_chat_by_id(id: str, user=Depends(get_verified_user)):
|
|
|
chat = Chats.get_chat_by_id_and_user_id(id, user.id)
|
|
|
if chat:
|
|
|
- chat_body = json.loads(chat.chat)
|
|
|
updated_chat = {
|
|
|
- **chat_body,
|
|
|
+ **chat.chat,
|
|
|
"originalChatId": chat.id,
|
|
|
- "branchPointMessageId": chat_body["history"]["currentId"],
|
|
|
+ "branchPointMessageId": chat.chat["history"]["currentId"],
|
|
|
"title": f"Clone of {chat.title}",
|
|
|
}
|
|
|
|
|
|
chat = Chats.insert_new_chat(user.id, ChatForm(**{"chat": updated_chat}))
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED, detail=ERROR_MESSAGES.DEFAULT()
|
|
@@ -338,7 +335,7 @@ async def archive_chat_by_id(id: str, user=Depends(get_verified_user)):
|
|
|
chat = Chats.get_chat_by_id_and_user_id(id, user.id)
|
|
|
if chat:
|
|
|
chat = Chats.toggle_chat_archive_by_id(id)
|
|
|
- return ChatResponse(**{**chat.model_dump(), "chat": json.loads(chat.chat)})
|
|
|
+ return ChatResponse(**chat.model_dump())
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED, detail=ERROR_MESSAGES.DEFAULT()
|
|
@@ -356,9 +353,7 @@ async def share_chat_by_id(id: str, user=Depends(get_verified_user)):
|
|
|
if chat:
|
|
|
if chat.share_id:
|
|
|
shared_chat = Chats.update_shared_chat_by_chat_id(chat.id)
|
|
|
- return ChatResponse(
|
|
|
- **{**shared_chat.model_dump(), "chat": json.loads(shared_chat.chat)}
|
|
|
- )
|
|
|
+ return ChatResponse(**shared_chat.model_dump())
|
|
|
|
|
|
shared_chat = Chats.insert_shared_chat_by_chat_id(chat.id)
|
|
|
if not shared_chat:
|
|
@@ -366,10 +361,8 @@ async def share_chat_by_id(id: str, user=Depends(get_verified_user)):
|
|
|
status_code=status.HTTP_500_INTERNAL_SERVER_ERROR,
|
|
|
detail=ERROR_MESSAGES.DEFAULT(),
|
|
|
)
|
|
|
+ return ChatResponse(**shared_chat.model_dump())
|
|
|
|
|
|
- return ChatResponse(
|
|
|
- **{**shared_chat.model_dump(), "chat": json.loads(shared_chat.chat)}
|
|
|
- )
|
|
|
else:
|
|
|
raise HTTPException(
|
|
|
status_code=status.HTTP_401_UNAUTHORIZED,
|