from __future__ import annotations import typing from . import chatcmpl from .. import requester from ....core import entities as core_entities from ... import entities as llm_entities from ...tools import entities as tools_entities class MoonshotChatCompletions(chatcmpl.OpenAIChatCompletions): """Moonshot ChatCompletion API 请求器""" default_config: dict[str, typing.Any] = { 'base_url': 'https://api.moonshot.cn/v1', 'timeout': 120, } async def _closure( self, query: core_entities.Query, req_messages: list[dict], use_model: requester.RuntimeLLMModel, use_funcs: list[tools_entities.LLMFunction] = None, extra_args: dict[str, typing.Any] = {}, ) -> llm_entities.Message: self.client.api_key = use_model.token_mgr.get_token() args = extra_args.copy() args['model'] = use_model.model_entity.name if use_funcs: tools = await self.ap.tool_mgr.generate_tools_for_openai(use_funcs) if tools: args['tools'] = tools # 设置此次请求中的messages messages = req_messages # deepseek 不支持多模态,把content都转换成纯文字 for m in messages: if 'content' in m and isinstance(m['content'], list): m['content'] = ' '.join([c['text'] for c in m['content']]) # 删除空的 messages = [m for m in messages if m['content'].strip() != ''] args['messages'] = messages # 发送请求 resp = await self._req(args) # 处理请求结果 message = await self._make_msg(resp) return message