From f8f1d6a91b32077c69dd97334559fe3165ff79b6 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Tue, 02 Sep 2025 13:45:20 +0800
Subject: [PATCH] feat(ai): 添加 AI 用户陪练(流式)功能

---
 src/main/java/cc/mrbird/febs/ai/service/AiService.java |   17 ++++++++++++++++-
 1 files changed, 16 insertions(+), 1 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/AiService.java b/src/main/java/cc/mrbird/febs/ai/service/AiService.java
index 04a87e9..50d8bfa 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/AiService.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/AiService.java
@@ -1,18 +1,29 @@
 package cc.mrbird.febs.ai.service;
 
+import cc.mrbird.febs.ai.req.ai.AiMessage;
 import cc.mrbird.febs.ai.req.ai.AiRequest;
+import cc.mrbird.febs.ai.req.talk.AiTalkAnswerStream;
 import cc.mrbird.febs.ai.res.ai.AiResponse;
 import cc.mrbird.febs.ai.res.ai.Report;
+import cc.mrbird.febs.common.entity.FebsResponse;
+import reactor.core.publisher.Flux;
+
+import java.util.List;
+import java.util.function.Consumer;
 
 /**
  * @author Administrator
  */
 public interface AiService {
 
+    Integer getSystemSetAiType();
 
-    AiResponse start(String productRoleId, String content);
+
+    AiResponse start(List<AiMessage> aiMessageDtoList,Integer type, String productRoleId, String answer, String question);
 
     AiResponse question(AiRequest aiRequest);
+
+    void streamQuestion(AiRequest aiRequest, Consumer<AiResponse> callback);
 
     /**
      * 从模型输出中提取并解析报告数据
@@ -20,4 +31,8 @@
      * @return 解析后的报告对象
      */
     Report extractReportData(String modelOutput);
+
+    Flux<FebsResponse> answerStream(String question);
+
+    Flux<FebsResponse> answerStreamV2(AiTalkAnswerStream dto);
 }

--
Gitblit v1.9.1