dan92 commited on
Commit
e3c38b5
·
verified ·
1 Parent(s): 93fe271

Update api/routes.py

Browse files
Files changed (1) hide show
  1. api/routes.py +94 -62
api/routes.py CHANGED
@@ -1,62 +1,94 @@
1
- import json
2
- from fastapi import APIRouter, Depends, HTTPException, Request, Response
3
- from fastapi.responses import StreamingResponse
4
- from api.auth import verify_app_secret
5
- from api.config import ALLOWED_MODELS
6
- from api.models import ChatRequest
7
- from api.utils import process_non_streaming_response, process_streaming_response
8
- from api.logger import setup_logger
9
-
10
- logger = setup_logger(__name__)
11
-
12
- router = APIRouter()
13
-
14
- @router.options("/v1/chat/completions")
15
- @router.options("/api/v1/chat/completions")
16
- async def chat_completions_options():
17
- return Response(
18
- status_code=200,
19
- headers={
20
- "Access-Control-Allow-Origin": "*",
21
- "Access-Control-Allow-Methods": "POST, OPTIONS",
22
- "Access-Control-Allow-Headers": "Content-Type, Authorization",
23
- },
24
- )
25
-
26
- @router.get("/v1/models")
27
- @router.get("/api/v1/models")
28
- async def list_models():
29
- return {"object": "list", "data": ALLOWED_MODELS}
30
-
31
- @router.post("/v1/chat/completions")
32
- @router.post("/api/v1/chat/completions")
33
- async def chat_completions(
34
- request: ChatRequest, app_secret: str = Depends(verify_app_secret)
35
- ):
36
- logger.info("Entering chat_completions route")
37
- logger.info(f"Received request: {request}")
38
- logger.info(f"App secret: {app_secret}")
39
- logger.info(f"Received chat completion request for model: {request.model}")
40
-
41
- if request.model not in [model["id"] for model in ALLOWED_MODELS]:
42
- raise HTTPException(
43
- status_code=400,
44
- detail=f"Model {request.model} is not allowed. Allowed models are: {', '.join(model['id'] for model in ALLOWED_MODELS)}",
45
- )
46
-
47
- if request.stream:
48
- logger.info("Streaming response")
49
- return StreamingResponse(process_streaming_response(request), media_type="text/event-stream")
50
- else:
51
- logger.info("Non-streaming response")
52
- return await process_non_streaming_response(request)
53
-
54
-
55
- @router.route('/')
56
- @router.route('/healthz')
57
- @router.route('/ready')
58
- @router.route('/alive')
59
- @router.route('/status')
60
- @router.get("/health")
61
- def health_check(request: Request):
62
- return Response(content=json.dumps({"status": "ok"}), media_type="application/json")
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import json
2
+ from fastapi import APIRouter, Depends, HTTPException, Request, Response
3
+ from fastapi.responses import StreamingResponse, JSONResponse
4
+ from api.auth import verify_app_secret
5
+ from api.config import ALLOWED_MODELS
6
+ from api.models import ChatRequest
7
+ from api.utils import process_non_streaming_response, process_streaming_response
8
+ from api.logger import setup_logger
9
+
10
+ logger = setup_logger(__name__)
11
+
12
+ router = APIRouter()
13
+
14
+ @router.options("/v1/chat/completions")
15
+ @router.options("/api/v1/chat/completions")
16
+ async def chat_completions_options():
17
+ return Response(
18
+ status_code=200,
19
+ headers={
20
+ "Access-Control-Allow-Origin": "*",
21
+ "Access-Control-Allow-Methods": "POST, OPTIONS",
22
+ "Access-Control-Allow-Headers": "Content-Type, Authorization",
23
+ },
24
+ )
25
+
26
+ @router.get("/v1/models")
27
+ @router.get("/api/v1/models")
28
+ async def list_models():
29
+ return {"object": "list", "data": ALLOWED_MODELS}
30
+
31
+ async def stream_wrapper(request: ChatRequest):
32
+ """包装流式响应,处理可能的错误"""
33
+ try:
34
+ async for chunk in process_streaming_response(request):
35
+ yield chunk
36
+ except Exception as e:
37
+ logger.error(f"Error in stream_wrapper: {str(e)}")
38
+ error_response = {
39
+ "error": {
40
+ "message": "抱歉,处理请求时出现错误,请重试",
41
+ "type": "stream_error",
42
+ "code": 500
43
+ }
44
+ }
45
+ yield f"data: {json.dumps(error_response)}\n\n"
46
+ yield "data: [DONE]\n\n"
47
+
48
+ @router.post("/v1/chat/completions")
49
+ @router.post("/api/v1/chat/completions")
50
+ async def chat_completions(
51
+ request: ChatRequest, app_secret: str = Depends(verify_app_secret)
52
+ ):
53
+ logger.info("Entering chat_completions route")
54
+ logger.info(f"Received request: {request}")
55
+ logger.info(f"App secret: {app_secret}")
56
+ logger.info(f"Received chat completion request for model: {request.model}")
57
+
58
+ if request.model not in [model["id"] for model in ALLOWED_MODELS]:
59
+ raise HTTPException(
60
+ status_code=400,
61
+ detail=f"Model {request.model} is not allowed. Allowed models are: {', '.join(model['id'] for model in ALLOWED_MODELS)}",
62
+ )
63
+
64
+ try:
65
+ if request.stream:
66
+ logger.info("Streaming response")
67
+ return StreamingResponse(
68
+ stream_wrapper(request),
69
+ media_type="text/event-stream",
70
+ headers={
71
+ "Cache-Control": "no-cache",
72
+ "Connection": "keep-alive",
73
+ "Transfer-Encoding": "chunked"
74
+ }
75
+ )
76
+ else:
77
+ logger.info("Non-streaming response")
78
+ return await process_non_streaming_response(request)
79
+ except Exception as e:
80
+ logger.error(f"Error in chat_completions: {str(e)}")
81
+ return JSONResponse(
82
+ status_code=500,
83
+ content={"error": "处理请求时出现错误,请重试"}
84
+ )
85
+
86
+
87
+ @router.route('/')
88
+ @router.route('/healthz')
89
+ @router.route('/ready')
90
+ @router.route('/alive')
91
+ @router.route('/status')
92
+ @router.get("/health")
93
+ def health_check(request: Request):
94
+ return Response(content=json.dumps({"status": "ok"}), media_type="application/json")