‼️🐛 fix: 修复钩子函数无法终止事件传播的问题;修复某些情况下终止事件传播后仍然会请求 LLM 的问题

This commit is contained in:
Soulter
2025-02-28 00:01:50 +08:00
parent aa3cfd887a
commit 7f6ed674b4
4 changed files with 20 additions and 0 deletions
@@ -75,6 +75,10 @@ class LLMRequestSubStage(Stage):
except BaseException:
logger.error(traceback.format_exc())
if event.is_stopped():
logger.info(f"{star_map[handler.handler_module_path].name} - {handler.handler_name} 终止了事件传播。")
return
if isinstance(req.contexts, str):
req.contexts = json.loads(req.contexts)
@@ -92,6 +96,11 @@ class LLMRequestSubStage(Stage):
await handler.handler(event, llm_response)
except BaseException:
logger.error(traceback.format_exc())
if event.is_stopped():
logger.info(f"{star_map[handler.handler_module_path].name} - {handler.handler_name} 终止了事件传播。")
return
# 保存到历史记录
await self._save_to_history(event, req, llm_response)
+4
View File
@@ -95,5 +95,9 @@ class RespondStage(Stage):
await handler.handler(event)
except BaseException:
logger.error(traceback.format_exc())
if event.is_stopped():
logger.info(f"{star_map[handler.handler_module_path].name} - {handler.handler_name} 终止了事件传播。")
return
event.clear_result()
@@ -70,6 +70,10 @@ class ResultDecorateStage(Stage):
logger.debug(f"hook(on_decorating_result) -> {star_map[handler.handler_module_path].name} - {handler.handler_name} 将消息结果清空。")
except BaseException:
logger.error(traceback.format_exc())
if event.is_stopped():
logger.info(f"{star_map[handler.handler_module_path].name} - {handler.handler_name} 终止了事件传播。")
return
# 需要再获取一次。插件可能直接对 chain 进行了替换。
result = event.get_result()
+3
View File
@@ -27,6 +27,9 @@ class PipelineScheduler():
logger.debug(f"阶段 {stage.__class__ .__name__} 已终止事件传播。")
break
await self._process_stages(event, i + 1)
if event.is_stopped():
logger.debug(f"阶段 {stage.__class__ .__name__} 已终止事件传播。")
break
else:
await coro