From e5e2be29cfc033c976558a4d0b5fa73426818b90 Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期三, 26 二月 2025 11:30:48 +0800
Subject: [PATCH] 增加系统信息修改

---
 app/api/v2/chat.py |   50 ++++++++++++++++++++++++++++++++++----------------
 1 files changed, 34 insertions(+), 16 deletions(-)

diff --git a/app/api/v2/chat.py b/app/api/v2/chat.py
index 2828bd2..a09ab43 100644
--- a/app/api/v2/chat.py
+++ b/app/api/v2/chat.py
@@ -1,9 +1,11 @@
 import json
 import uuid
+from typing import List
 
-from fastapi import Depends, APIRouter
+from fastapi import Depends, APIRouter, File, UploadFile
 from sqlalchemy.orm import Session
 from starlette.responses import StreamingResponse, Response
+from werkzeug.http import HTTP_STATUS_CODES
 
 from app.api import get_current_user
 from app.config.const import dialog_chat, advanced_chat, base_chat, agent_chat, workflow_chat, basic_chat, \
@@ -12,12 +14,13 @@
 from app.models.base_model import get_db
 from app.models.v2.session_model import ChatData
 from app.service.v2.chat import service_chat_dialog, get_chat_info, service_chat_basic, \
-    service_chat_workflow, service_chat_parameters, service_chat_sessions
+    service_chat_workflow, service_chat_parameters, service_chat_sessions, service_chat_upload, \
+    service_chat_sessions_list, service_chat_session_log
 
 chat_router_v2 = APIRouter()
 
 # 瀵硅瘽
-@chat_router_v2.post("/{chatId}/dialog")
+@chat_router_v2.post("/chat/{chatId}/completions")
 async def api_chat_dialog(chatId:str, dialog: ChatData, current_user: UserModel = Depends(get_current_user),db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
     chat_info = await get_chat_info(db, chatId)
     if not chat_info:
@@ -42,7 +45,7 @@
     return StreamingResponse(service_chat_dialog(db, chatId, dialog.query, session_id, current_user.id, chat_info.mode),
                              media_type="text/event-stream")
 
-@chat_router_v2.post("/{chatId}/agent")
+@chat_router_v2.post("/agent/{chatId}/completions")
 async def api_chat_dialog(chatId:str, dialog: ChatData, current_user: UserModel = Depends(get_current_user),db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
     chat_info = await get_chat_info(db, chatId)
     if not chat_info:
@@ -57,7 +60,7 @@
                              media_type="text/event-stream")
 
 
-@chat_router_v2.post("/{chatId}/workflow")
+@chat_router_v2.post("/workflow/{chatId}/completions")
 async def api_chat_dialog(chatId:str, dialog: ChatData, current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
     chat_info = await get_chat_info(db, chatId)
     if not chat_info:
@@ -72,7 +75,7 @@
                              media_type="text/event-stream")
 
 
-@chat_router_v2.post("/{chatId}/basic")
+@chat_router_v2.post("/complex/{chatId}/completions")
 async def api_chat_dialog(chatId:str, dialog: ChatData, current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
     chat_info = await get_chat_info(db, chatId)
     if not chat_info:
@@ -90,19 +93,34 @@
 
 
 
-@chat_router_v2.get("/{chatId}/parameters")
-async def api_chat_parameters(chatId:str, db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
+@chat_router_v2.get("/chat/{chatId}/parameters")
+async def api_chat_parameters(chatId:str, current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
     status_code = http_200
-    data = await service_chat_parameters(db, chatId, 1)
+    data = await service_chat_parameters(db, chatId, current_user.id)
+    if not data:
+        status_code = http_400
+        data = json.dumps({"code": http_400})
+    return Response(data, media_type="application/json", status_code=status_code)
+
+
+@chat_router_v2.post("/{chatId}/upload")
+async def api_chat_upload(chatId:str, file: List[UploadFile] = File(...), current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
+    status_code = http_200
+    data = await service_chat_upload(db, chatId, file, current_user.id)
     if not data:
         status_code = http_400
         data = "{}"
     return Response(data, media_type="application/json", status_code=status_code)
 
-# @chat_router_v2.get("/{chatId}/parameters")
-# async def api_chat_parameters(chatId:str, db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
-#     status_code = http_200
-#     data = await service_chat_parameters(db, chatId, 1)
-#     if not data:
-#         status_code = http_400
-#     return Response(json.dumps(data), media_type="application/json", status_code=status_code)
\ No newline at end of file
+
+
+@chat_router_v2.get("/chat/sessions")
+async def api_chat_sessions(chatId:str, current:int=1, pageSize:int=100, keyword:str="", current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
+    data = await service_chat_sessions_list(db, chatId, current, pageSize, current_user.id, keyword)
+    return Response(data, media_type="application/json", status_code=http_200)
+
+
+@chat_router_v2.get("/chat/session_log")
+async def api_chat_sessions(sessionId:str, current_user: UserModel = Depends(get_current_user), db: Session = Depends(get_db)): #  current_user: UserModel = Depends(get_current_user)
+    data = await service_chat_session_log(db, sessionId)
+    return Response(data, media_type="application/json", status_code=http_200)
\ No newline at end of file

--
Gitblit v1.8.0