From 18fdf89338e84e1cab48c2795631777e22b05b81 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Wed, 03 Sep 2025 14:37:54 +0800
Subject: [PATCH] feat(ai): 添加灵通角色设定PROMPT功能

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java |   12 +++++++++---
 1 files changed, 9 insertions(+), 3 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
index 3d7be4e..7f6951f 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java
@@ -16,6 +16,7 @@
 import cc.mrbird.febs.ai.service.AiTalkItemService;
 import cc.mrbird.febs.ai.service.AiTalkService;
 import cc.mrbird.febs.ai.strategy.LlmStrategyFactory;
+import cc.mrbird.febs.ai.strategy.enumerates.LlmStrategyContextEnum;
 import cc.mrbird.febs.ai.strategy.enumerates.LlmStrategyEnum;
 import cc.mrbird.febs.ai.strategy.param.LlmStrategyDto;
 import cc.mrbird.febs.ai.utils.UUID;
@@ -25,6 +26,7 @@
 import cn.hutool.core.date.DateTime;
 import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.StrUtil;
+import cn.hutool.json.JSONUtil;
 import com.alibaba.dashscope.common.Role;
 import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -37,6 +39,7 @@
 
 import java.util.ArrayList;
 import java.util.Date;
+import java.util.HashMap;
 import java.util.List;
 
 @Slf4j
@@ -71,6 +74,7 @@
         String talkId = dto.getTalkId();
         String context = dto.getContext();
         Integer type = dto.getType();
+        String reasoningContent = dto.getReasoningContent();
         String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
 
         AiTalk aiTalk = this.getById(talkId);
@@ -78,8 +82,10 @@
         if (StrUtil.isEmpty(talkId)){
             aiTalk = this.add(memberUuid,context, date);
         }
-
-        aiTalkItemService.add(aiTalk.getId(), type, context, memberUuid, date);
+        HashMap<String, String> stringStringHashMap = new HashMap<>();
+        stringStringHashMap.put(LlmStrategyContextEnum.THINK.getName(),reasoningContent);
+        stringStringHashMap.put(LlmStrategyContextEnum.CONTENT.getName(),context);
+        aiTalkItemService.add(aiTalk.getId(), type, JSONUtil.toJsonStr(stringStringHashMap), memberUuid, date);
 
         ApiTalkVo apiTalkVo = new ApiTalkVo();
         apiTalkVo.setTalkId(aiTalk.getId());
@@ -132,7 +138,7 @@
         if (dto.getPrompt() != null){
             LlmStrategyDto llmStrategyDto = new LlmStrategyDto();
             llmStrategyDto.setRole(Role.SYSTEM.getValue());
-            llmStrategyDto.setContent(AiPromptEnum.STREAM_NORMAL.getPrompt());
+            llmStrategyDto.setContent(aiService.getSystemSetLTAiPrompt());
             llmStrategyDtoList.add(llmStrategyDto);
         }
         if (dto.getQuestion() != null){

--
Gitblit v1.9.1