Files
LangBot/pkg/pipeline/process/handlers/chat.py

113 lines
3.9 KiB
Python
Raw Normal View History

from __future__ import annotations
import typing
2024-01-31 00:02:19 +08:00
import time
2024-02-01 18:11:47 +08:00
import traceback
import mirai
from .. import handler
from ... import entities
from ....core import entities as core_entities
2024-01-28 19:20:10 +08:00
from ....provider import entities as llm_entities
2024-01-30 21:45:17 +08:00
from ....plugin import events
class ChatMessageHandler(handler.MessageHandler):
async def handle(
self,
query: core_entities.Query,
) -> typing.AsyncGenerator[entities.StageProcessResult, None]:
"""处理
"""
# 取session
# 取conversation
# 调API
# 生成器
2024-01-30 21:45:17 +08:00
# 触发插件事件
event_class = events.PersonNormalMessageReceived if query.launcher_type == core_entities.LauncherTypes.PERSON else events.GroupNormalMessageReceived
2024-01-30 21:45:17 +08:00
event_ctx = await self.ap.plugin_mgr.emit_event(
event=event_class(
launcher_type=query.launcher_type.value,
launcher_id=query.launcher_id,
sender_id=query.sender_id,
text_message=str(query.message_chain),
query=query
2024-01-28 18:21:43 +08:00
)
)
2024-01-30 21:45:17 +08:00
if event_ctx.is_prevented_default():
if event_ctx.event.reply is not None:
query.resp_message_chain = mirai.MessageChain(event_ctx.event.reply)
2024-01-27 21:50:40 +08:00
2024-01-30 21:45:17 +08:00
yield entities.StageProcessResult(
result_type=entities.ResultType.CONTINUE,
new_query=query
)
else:
yield entities.StageProcessResult(
result_type=entities.ResultType.INTERRUPT,
new_query=query
)
else:
2024-02-06 21:26:03 +08:00
if not self.ap.provider_cfg.data['enable-chat']:
yield entities.StageProcessResult(
result_type=entities.ResultType.INTERRUPT,
new_query=query,
)
2024-01-30 21:45:17 +08:00
if event_ctx.event.alter is not None:
query.message_chain = mirai.MessageChain([
mirai.Plain(event_ctx.event.alter)
])
2024-02-01 16:35:00 +08:00
query.messages.append(
query.user_message
2024-01-30 21:45:17 +08:00
)
2024-01-31 00:02:19 +08:00
text_length = 0
start_time = time.time()
2024-02-01 16:43:44 +08:00
try:
2024-01-30 21:45:17 +08:00
2024-02-01 16:43:44 +08:00
async for result in query.use_model.requester.request(query):
query.resp_messages.append(result)
2024-02-01 16:35:00 +08:00
self.ap.logger.info(f'对话({query.query_id})响应: {self.cut_str(result.readable_str())}')
2024-02-01 16:43:44 +08:00
if result.content is not None:
text_length += len(result.content)
2024-01-31 00:02:19 +08:00
2024-02-01 16:43:44 +08:00
yield entities.StageProcessResult(
result_type=entities.ResultType.CONTINUE,
new_query=query
)
2024-02-01 18:11:47 +08:00
except Exception as e:
self.ap.logger.error(f'对话({query.query_id})请求失败: {str(e)}')
2024-02-01 18:11:47 +08:00
yield entities.StageProcessResult(
result_type=entities.ResultType.INTERRUPT,
new_query=query,
2024-02-06 21:26:03 +08:00
user_notice='请求失败' if self.ap.platform_cfg.data['hide-exception-info'] else f'{e}',
2024-02-01 18:11:47 +08:00
error_notice=f'{e}',
debug_notice=traceback.format_exc()
)
2024-02-01 16:43:44 +08:00
finally:
query.session.using_conversation.messages.append(query.user_message)
query.session.using_conversation.messages.extend(query.resp_messages)
2024-02-01 17:42:51 +08:00
await self.ap.ctr_mgr.usage.post_query_record(
session_type=query.session.launcher_type.value,
session_id=str(query.session.launcher_id),
query_ability_provider="QChatGPT.Chat",
usage=text_length,
model_name=query.use_model.name,
response_seconds=int(time.time() - start_time),
retry_times=-1,
)