From 0be80a07e38f08dd40e20175d788a3bfad8e68ef Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 11 Aug 2025 11:41:24 +0800
Subject: [PATCH] feat(ai): 增加 AI 陪练报告数据解析功能 - 新增 Report、RadarData 和 Evaluation 类用于解析报告数据 - 在 AiService 接口中添加 extractReportData 方法 - 在 AiServiceImpl 中实现报告数据的提取和解析 - 更新 ApiMemberTalkVo,增加 report 字段用于存储解析后的报告数据 - 修改前端相关的回答格式和类型

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java |   72 ++++++++++++++++++++++++++++++++++++
 1 files changed, 72 insertions(+), 0 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
index 6c88c98..db3d4ba 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberTalkServiceImpl.java
@@ -4,6 +4,7 @@
 import cc.mrbird.febs.ai.entity.AiMemberTalkItem;
 import cc.mrbird.febs.ai.entity.AiProductRoleLink;
 import cc.mrbird.febs.ai.mapper.AiMemberTalkMapper;
+import cc.mrbird.febs.ai.req.ai.AiRequest;
 import cc.mrbird.febs.ai.req.memberTalk.ApiMemberTalkAnswerDto;
 import cc.mrbird.febs.ai.req.memberTalk.ApiMemberTalkDto;
 import cc.mrbird.febs.ai.res.ai.AiResponse;
@@ -26,6 +27,7 @@
 import org.springframework.stereotype.Service;
 
 import java.util.Date;
+import java.util.function.Consumer;
 
 /**
  * AI用户对话训练记录 Service实现类
@@ -90,6 +92,76 @@
     }
 
     @Override
+    public void startStream(ApiMemberTalkDto dto, Consumer<AiResponse> callback) {
+        try {
+            String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+            String productId = dto.getId();
+
+            LambdaQueryWrapper<AiProductRoleLink> productLinkQuery = Wrappers.lambdaQuery(AiProductRoleLink.class);
+            productLinkQuery.eq(AiProductRoleLink::getProductId, productId);
+            productLinkQuery.last("limit 1");
+            AiProductRoleLink aiProductRoleLink = aiProductRoleLinkService.getByQuery(productLinkQuery);
+            if (ObjectUtil.isNull(aiProductRoleLink)) {
+                AiResponse aiResponse = new AiResponse();
+                aiResponse.setCode("500");
+                aiResponse.setDescription("产品AI陪练不存在");
+                callback.accept(aiResponse);
+                return;
+            }
+
+            // 构造AI请求
+            AiRequest aiRequest = new AiRequest();
+            aiRequest.setLinkId(aiProductRoleLink.getProductRoleId());
+            aiRequest.setPromptTemplate(aiProductRoleLink.getProductRoleId());
+            aiRequest.setContent("<strong>\"生成题目\"</strong>");
+
+            // 定义AI服务回调处理
+            Consumer<AiResponse> aiCallback = aiResponse -> {
+                Date nowTime = new Date();
+                LambdaQueryWrapper<AiMemberTalk> query = Wrappers.lambdaQuery(AiMemberTalk.class);
+                query.eq(AiMemberTalk::getMemberId, memberUuid);
+                query.eq(AiMemberTalk::getProductId, productId);
+                query.last("limit 1");
+                AiMemberTalk aiMemberTalk = this.getByQuery(query);
+                if (ObjectUtil.isNull(aiMemberTalk)) {
+                    aiMemberTalk = this.add(memberUuid, productId, nowTime);
+                }
+                try {
+                    if (aiResponse.getCode().equals("200")) {
+                        // 如果是最终结果(包含报告)
+                        if (aiResponse.getReport() != null) {
+                            // 保存完整响应到数据库
+                            aiMemberTalkItemService.add(memberUuid, aiMemberTalk.getId(), 1, aiResponse.getResContext(), nowTime);
+                            this.updateTimeUpdate(nowTime, aiMemberTalk.getId());
+
+                            callback.accept(aiResponse);
+                        } else {
+                            // 流式响应片段
+                            callback.accept(aiResponse);
+                        }
+                    } else {
+                        callback.accept(aiResponse);
+                    }
+                } catch (Exception e) {
+                    log.error("处理AI响应异常", e);
+                    callback.accept(aiResponse);
+                }
+            };
+
+            // 调用AI服务的流式接口
+            aiService.streamQuestion(aiRequest, aiCallback);
+
+        } catch (Exception e) {
+            log.error("流式调用start方法异常", e);
+
+            AiResponse aiResponse = new AiResponse();
+            aiResponse.setCode("500");
+            aiResponse.setDescription("流式调用start方法异常");
+            callback.accept(aiResponse);
+        }
+    }
+
+    @Override
     public AiMemberTalk getByQuery(LambdaQueryWrapper<AiMemberTalk> query) {
         return aiMemberTalkMapper.selectOne( query);
     }

--
Gitblit v1.9.1