From 413a57e2524cb0b839d5d83d961de3b59814eb6e Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 24 Oct 2025 16:53:11 +0800
Subject: [PATCH] feat(ai): 实现产品依赖解锁功能 - 在AiMemberAnswerServiceImpl中注入AiProductDependencyService和AiMemberProductUnlockService - 修改insure方法,根据答题分数解锁符合条件的产品 - 新增selectListByProductIds和insertList方法到AiMemberProductUnlockService - 实现产品依赖关系查询方法selectListByProductId到AiProductDependencyService- 在AiProductServiceImpl中增加产品状态判断逻辑,支持锁定和解锁状态显示 - 添加memberId字段到ApiProductPageDto用于查询用户已解锁产品 - 在ApiProductVo中新增state字段表示产品锁定/解锁状态
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiTalkServiceImpl.java | 70 ++++++++++++++++++++++++++++++----
1 files changed, 61 insertions(+), 9 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 2cabe56..1480379 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
@@ -2,12 +2,9 @@
import cc.mrbird.febs.ai.entity.AiProductQuestion;
import cc.mrbird.febs.ai.entity.AiTalk;
+import cc.mrbird.febs.ai.enumerates.AiPromptEnum;
import cc.mrbird.febs.ai.mapper.AiTalkMapper;
-import cc.mrbird.febs.ai.req.talk.AiTalkAnswerStream;
-import cc.mrbird.febs.ai.req.talk.ApiTalkDto;
-import cc.mrbird.febs.ai.req.talk.ApiTalkItemPageDto;
-import cc.mrbird.febs.ai.req.talk.ApiTalkPageDto;
-import cc.mrbird.febs.ai.res.memberAnswer.ApiMemberProductWorkVo;
+import cc.mrbird.febs.ai.req.talk.*;
import cc.mrbird.febs.ai.res.talk.ApiTalkPageVo;
import cc.mrbird.febs.ai.res.talk.ApiTalkQuestionVo;
import cc.mrbird.febs.ai.res.talk.ApiTalkVo;
@@ -15,6 +12,10 @@
import cc.mrbird.febs.ai.service.AiService;
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;
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.utils.LoginUserUtil;
@@ -22,6 +23,8 @@
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;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
@@ -33,6 +36,7 @@
import java.util.ArrayList;
import java.util.Date;
+import java.util.HashMap;
import java.util.List;
@Slf4j
@@ -43,6 +47,7 @@
private final AiTalkItemService aiTalkItemService;
private final AiProductQuestionService aiProductQuestionService;
private final AiService aiService;
+ private final LlmStrategyFactory llmStrategyFactory;
@Override
public FebsResponse questionList() {
@@ -62,19 +67,45 @@
}
@Override
+ public FebsResponse questionListV2(ApiQuestionListDto dto) {
+ List<ApiTalkQuestionVo> list = new ArrayList<>();
+ LambdaQueryWrapper<AiProductQuestion> queryWrapper = Wrappers.lambdaQuery(AiProductQuestion.class);
+ if (StrUtil.isNotEmpty(dto.getCompanyId())){
+ queryWrapper.eq(AiProductQuestion::getCompanyId,dto.getCompanyId());
+ }else{
+ queryWrapper.isNull(AiProductQuestion::getCompanyId);
+ }
+ queryWrapper.orderByDesc(AiProductQuestion::getCreatedTime);
+ queryWrapper.last("limit 30");
+ List<AiProductQuestion> listByQuery = aiProductQuestionService.getListByQuery(queryWrapper);
+ if (CollUtil.isNotEmpty(listByQuery)){
+ for (AiProductQuestion aiProductQuestion : listByQuery){
+ ApiTalkQuestionVo apiTalkQuestionVo = new ApiTalkQuestionVo();
+ apiTalkQuestionVo.setContext(aiProductQuestion.getTitle());
+ list.add(apiTalkQuestionVo);
+ }
+ }
+ return new FebsResponse().success().data(list);
+ }
+
+ @Override
public FebsResponse talkOpen(ApiTalkDto dto) {
String talkId = dto.getTalkId();
String context = dto.getContext();
Integer type = dto.getType();
+ String reasoningContent = dto.getReasoningContent();
String memberUuid = LoginUserUtil.getLoginUser().getMemberUuid();
+ String companyId = LoginUserUtil.getLoginUser().getCompanyId();
AiTalk aiTalk = this.getById(talkId);
DateTime date = DateUtil.date();
if (StrUtil.isEmpty(talkId)){
- aiTalk = this.add(memberUuid,context, date);
+ aiTalk = this.add(memberUuid,companyId,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(), companyId,type, JSONUtil.toJsonStr(stringStringHashMap), memberUuid, date);
ApiTalkVo apiTalkVo = new ApiTalkVo();
apiTalkVo.setTalkId(aiTalk.getId());
@@ -82,9 +113,10 @@
}
@Override
- public AiTalk add(String memberUuid, String question, Date date) {
+ public AiTalk add(String memberUuid,String companyId, String question, Date date) {
AiTalk aiTalk = new AiTalk();
aiTalk.setId(UUID.getSimpleUUIDString());
+ aiTalk.setCompanyId(companyId);
aiTalk.setQuestion(question);
aiTalk.setCreatedTime(date);
aiTalk.setMemberId(memberUuid);
@@ -121,4 +153,24 @@
return aiService.answerStreamV2(dto);
}
+ @Override
+ public Flux<FebsResponse> answerStreamV3(AiTalkAnswerStream dto) {
+ ArrayList<LlmStrategyDto> llmStrategyDtoList = new ArrayList<>();
+ if (dto.getPrompt() != null){
+ LlmStrategyDto llmStrategyDto = new LlmStrategyDto();
+ llmStrategyDto.setRole(Role.SYSTEM.getValue());
+ llmStrategyDto.setContent(aiService.getSystemSetLTAiPrompt());
+ llmStrategyDtoList.add(llmStrategyDto);
+ }
+ if (dto.getQuestion() != null){
+ LlmStrategyDto llmStrategyDto = new LlmStrategyDto();
+ llmStrategyDto.setRole(Role.USER.getValue());
+ String format = StrUtil.format("请使用中文回答:{}", dto.getQuestion());
+ llmStrategyDto.setContent(format);
+ llmStrategyDtoList.add(llmStrategyDto);
+ }
+ String modelName = LlmStrategyEnum.getName(aiService.getSystemSetAiType());
+ return llmStrategyFactory.getCalculationStrategyMap().get(modelName).llmInvokeStreamingWithThink(llmStrategyDtoList);
+ }
+
}
--
Gitblit v1.9.1