From 81d15b609a4588a4a36e4e0c30338f73e0a53da0 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 12 Sep 2025 17:27:43 +0800
Subject: [PATCH] feat(ai): 新增产品分类相关功能

---
 src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java |   81 ++++++++++++++++++++++++++++++++++++++--
 1 files changed, 76 insertions(+), 5 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
index 3b1b327..ff0df55 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/ApiMemberTalkStreamServiceImpl.java
@@ -119,6 +119,20 @@
     }
 
     @Override
+    public FebsResponse saveMemberAnswer(ApiMemberTalkMemberAnswerSavaDto dto) {
+        String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+        String memberTalkId = dto.getMemberTalkId();
+        String content = dto.getContent();
+
+        AiMemberTalk aiMemberTalk = this.getById(memberTalkId);
+        if (ObjectUtil.isNull(aiMemberTalk)){
+            throw new FebsException("对话不存在");
+        }
+        aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),2,content,new Date());
+        return new FebsResponse().success();
+    }
+
+    @Override
     public Flux<FebsResponse> answer(AiTalkAnswerStreamDto dto) {
 
         String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
@@ -151,13 +165,15 @@
         memberTalkItemQuery.orderByDesc(AiMemberTalkItem::getCreatedTime);
         memberTalkItemQuery.last("limit 1");
         AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.getByQuery(memberTalkItemQuery);
-        aiMemberTalkItemService.add(memberUuid,aiMemberTalk.getId(),2,reqContext,new Date());
+        String question = aiMemberTalkItem.getContext();
 
-        String prompt = this.buildPrompt(aiProductRole.getPromptHead(), aiProductRole.getPromptTemplate(), type);
+        String prompt = this.buildPrompt(question,reqContext,aiProductRole.getPromptHead(), aiProductRole.getPromptTemplate(), type);
 
 
         List<LlmStrategyDto> llmStrategyDtoList = new ArrayList<>();
         LlmStrategyDto llmStrategyDto = this.buildLlmStrategyDtoList(prompt, 1);
+        llmStrategyDtoList.add(llmStrategyDto);
+        llmStrategyDto = this.buildLlmStrategyDtoList(question, 3);
         llmStrategyDtoList.add(llmStrategyDto);
         llmStrategyDto = this.buildLlmStrategyDtoList(reqContext, 2);
         llmStrategyDtoList.add(llmStrategyDto);
@@ -166,10 +182,62 @@
         return llmStrategyFactory.getCalculationStrategyMap().get(modelName).llmInvokeStreamingNoThink(llmStrategyDtoList);
     }
 
-    private String buildPrompt(String promptHead, String promptTemplate,Integer type){
+    @Override
+    public Flux<FebsResponse> answerV2(AiTalkAnswerStreamDto dto) {
+
+
+        String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+        Integer type = dto.getType();
+        String memberTalkId = dto.getId();
+        AiMemberTalk aiMemberTalk = this.getById(memberTalkId);
+        if (ObjectUtil.isNull(aiMemberTalk)){
+            throw new FebsException("对话不存在");
+        }
+
+        LambdaQueryWrapper<AiProductRoleLink> productLinkQuery = Wrappers.lambdaQuery(AiProductRoleLink.class);
+        productLinkQuery.eq(AiProductRoleLink::getProductId,aiMemberTalk.getProductId());
+        productLinkQuery.last("limit 1");
+        AiProductRoleLink aiProductRoleLink = aiProductRoleLinkService.getByQuery(productLinkQuery);
+        if(ObjectUtil.isNull(aiProductRoleLink)){
+            throw new FebsException("产品没有关联AI陪练");
+        }
+
+        String productRoleId = aiProductRoleLink.getProductRoleId();
+        AiProductRole aiProductRole = aiProductRoleService.getById(productRoleId);
+        if (ObjectUtil.isNull(aiProductRole)){
+            throw new FebsException("产品AI陪练不存在");
+        }
+        LambdaQueryWrapper<AiMemberTalkItem> memberTalkItemQuery = Wrappers.lambdaQuery(AiMemberTalkItem.class);
+        memberTalkItemQuery.eq(AiMemberTalkItem::getMemberId,memberUuid);
+        memberTalkItemQuery.eq(AiMemberTalkItem::getMemberTalkId,memberTalkId);
+        memberTalkItemQuery.eq(AiMemberTalkItem::getType,1);
+        memberTalkItemQuery.orderByDesc(AiMemberTalkItem::getCreatedTime);
+        memberTalkItemQuery.last("limit 1");
+        AiMemberTalkItem aiMemberTalkItem = aiMemberTalkItemService.getByQuery(memberTalkItemQuery);
+
+        String question = aiMemberTalkItem.getContext();
+        String promptHead = aiProductRole.getPromptHead();
+        String answer = dto.getReqContext();
+
+        List<LlmStrategyDto> llmStrategyDtoList = new ArrayList<>();
+        LlmStrategyDto llmStrategyDto = this.buildLlmStrategyDtoList(promptHead, 1);
+        llmStrategyDtoList.add(llmStrategyDto);
+        llmStrategyDto = this.buildLlmStrategyDtoList(question, 3);
+        llmStrategyDtoList.add(llmStrategyDto);
+        llmStrategyDto = this.buildLlmStrategyDtoList(answer, 2);
+        llmStrategyDtoList.add(llmStrategyDto);
+        llmStrategyDto = this.buildLlmStrategyDtoList(String.valueOf(type), 4);
+        llmStrategyDtoList.add(llmStrategyDto);
+        String modelName = LlmStrategyEnum.getName(aiService.getSystemSetAiType());
+
+        return llmStrategyFactory.getCalculationStrategyMap().get(modelName).llmInvokeStreamingNoThink(llmStrategyDtoList);
+    }
+
+    private String buildPrompt(String question,String answer,String promptHead, String promptTemplate,Integer type){
         AiPromptJsonReq aiPromptJsonReq = new AiPromptJsonReq();
-        aiPromptJsonReq.setTask(promptHead);
-        aiPromptJsonReq.setRule(promptTemplate);
+//        aiPromptJsonReq.setQuestion( question);
+        aiPromptJsonReq.setTask( promptHead);
+        aiPromptJsonReq.setRule( promptTemplate);
         String contentByCode = AiTalkOutputEnum.HIGH_LIGHT.getContentByType(type);
         aiPromptJsonReq.setOutputFormat(contentByCode);
 
@@ -187,6 +255,9 @@
         if (type == 3){
             llmStrategyDto.setRole(Role.ASSISTANT.getValue());
         }
+        if (type == 4){
+            llmStrategyDto.setRole(Role.TOOL.getValue());
+        }
         llmStrategyDto.setContent(Str);
 
         return llmStrategyDto;

--
Gitblit v1.9.1