mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-14 21:52:56 +08:00
✨ feat(llm): 为 OpenAI 兼容请求体添加日志净化
This commit is contained in:
parent
fea9be8c63
commit
db53afbabc
@ -187,8 +187,12 @@ class LLMModel(LLMModelBase):
|
||||
logger.debug(f"🔑 API密钥: {masked_key}")
|
||||
logger.debug(f"📋 请求头: {dict(request_data.headers)}")
|
||||
|
||||
sanitizer_req_context_map = {"gemini": "gemini_request"}
|
||||
sanitizer_req_context = sanitizer_req_context_map.get(
|
||||
self.api_type, "openai_request"
|
||||
)
|
||||
sanitized_body = sanitize_for_logging(
|
||||
request_data.body, context="gemini_request"
|
||||
request_data.body, context=sanitizer_req_context
|
||||
)
|
||||
request_body_str = json.dumps(sanitized_body, ensure_ascii=False, indent=2)
|
||||
logger.debug(f"📦 请求体: {request_body_str}")
|
||||
|
||||
@ -50,6 +50,29 @@ def _sanitize_openai_response(response_json: dict) -> dict:
|
||||
return response_json
|
||||
|
||||
|
||||
def _sanitize_openai_request(body: dict) -> dict:
|
||||
"""净化OpenAI兼容API的请求体,主要截断图片base64。"""
|
||||
try:
|
||||
sanitized_json = copy.deepcopy(body)
|
||||
if "messages" in sanitized_json and isinstance(
|
||||
sanitized_json["messages"], list
|
||||
):
|
||||
for message in sanitized_json["messages"]:
|
||||
if "content" in message and isinstance(message["content"], list):
|
||||
for i, part in enumerate(message["content"]):
|
||||
if part.get("type") == "image_url":
|
||||
if "image_url" in part and isinstance(
|
||||
part["image_url"], dict
|
||||
):
|
||||
url = part["image_url"].get("url", "")
|
||||
message["content"][i]["image_url"]["url"] = (
|
||||
_truncate_base64_string(url)
|
||||
)
|
||||
return sanitized_json
|
||||
except Exception:
|
||||
return body
|
||||
|
||||
|
||||
def _sanitize_gemini_response(response_json: dict) -> dict:
|
||||
"""净化Gemini API的响应体,处理文本和图片生成两种格式。"""
|
||||
try:
|
||||
@ -147,6 +170,9 @@ def sanitize_for_logging(data: Any, context: str | None = None) -> Any:
|
||||
elif context == "gemini_request":
|
||||
if isinstance(data, dict):
|
||||
return _sanitize_gemini_request(data)
|
||||
elif context == "openai_request":
|
||||
if isinstance(data, dict):
|
||||
return _sanitize_openai_request(data)
|
||||
else:
|
||||
if isinstance(data, str):
|
||||
return _truncate_base64_string(data)
|
||||
|
||||
Loading…
Reference in New Issue
Block a user