From c8e3460c5aefedfa45dc19a7a8d5720a10d0f058 Mon Sep 17 00:00:00 2001 From: Administrator <15274802129@163.com> Date: Tue, 23 Sep 2025 15:38:44 +0800 Subject: [PATCH] feat(ai): 引入LlmApplicationAppIdEnum枚举优化工作流类型管理 --- src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java | 55 ++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 48 insertions(+), 7 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java index f68864b..9c311a9 100644 --- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java @@ -2,13 +2,14 @@ import cc.mrbird.febs.ai.entity.AiCompany; import cc.mrbird.febs.ai.entity.AiCompanyWorkflow; -import cc.mrbird.febs.ai.entity.AiMemberRole; +import cc.mrbird.febs.ai.enums.LlmApplicationAppIdEnum; import cc.mrbird.febs.ai.mapper.AiCompanyMapper; import cc.mrbird.febs.ai.mapper.AiCompanyWorkflowMapper; import cc.mrbird.febs.ai.service.AiCompanyService; import cc.mrbird.febs.ai.util.UUID; import cc.mrbird.febs.common.entity.FebsResponse; import cc.mrbird.febs.common.entity.QueryRequest; +import cn.hutool.core.collection.CollUtil; import cn.hutool.core.util.ObjectUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; @@ -19,7 +20,8 @@ import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; -import java.util.Date; +import java.util.*; +import java.util.stream.Collectors; @Slf4j @Service @@ -35,6 +37,13 @@ } @Override + public List<AiCompany> getListById(List<String> ids) { + LambdaQueryWrapper<AiCompany> aiCompanyLambdaQueryWrapper = Wrappers.lambdaQuery(AiCompany.class); + aiCompanyLambdaQueryWrapper.in(AiCompany::getId, ids); + return aiCompanyMapper.selectList(aiCompanyLambdaQueryWrapper); + } + + @Override public FebsResponse add(AiCompany dto) { Date createTime = new Date(); AiCompany entity = new AiCompany(); @@ -45,11 +54,12 @@ - this.addWorkflow(entity.getId(),1,null,createTime); - this.addWorkflow(entity.getId(),2,null,createTime); - this.addWorkflow(entity.getId(),3,null,createTime); - this.addWorkflow(entity.getId(),4,null,createTime); - this.addWorkflow(entity.getId(),6,null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.HIGH_LIGHT.getCode(),null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.SUGGESTION.getCode(),null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.REFERENCE_ANSWER.getCode(),null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.KEY_KNOWLEDGE.getCode(),null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.REPORT.getCode(),null,createTime); + this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.ADMIN_QUESTION.getCode(),null,createTime); return new FebsResponse().success().message("操作成功"); } @@ -84,11 +94,42 @@ } @Override + public AiCompanyWorkflow getWorkflowByTypeAndCompanyId(int type, String companyId) { + + LambdaQueryWrapper<AiCompanyWorkflow> query = Wrappers.lambdaQuery(AiCompanyWorkflow.class); + query.eq(AiCompanyWorkflow::getCompanyId, companyId); + query.eq(AiCompanyWorkflow::getType, type); + query.last("limit 1"); + return aiCompanyWorkflowMapper.selectOne(query); + } + + @Override public IPage<AiCompanyWorkflow> workflowListInPage(AiCompanyWorkflow dto, QueryRequest request) { Page<AiCompanyWorkflow> page = new Page<>(request.getPageNum(), request.getPageSize()); LambdaQueryWrapper<AiCompanyWorkflow> query = Wrappers.lambdaQuery(AiCompanyWorkflow.class); query.orderByDesc(AiCompanyWorkflow::getCreatedTime); Page<AiCompanyWorkflow> pages = aiCompanyWorkflowMapper.selectPage(page, query); + + List<AiCompanyWorkflow> records = pages.getRecords(); + if (CollUtil.isNotEmpty( records)){ + Set<String> collect = records.stream().map(AiCompanyWorkflow::getCompanyId).collect(Collectors.toSet()); + + + Map<String, AiCompany> map = new HashMap<>(); + if (CollUtil.isNotEmpty( collect)){ + //set转list + List<String> collect1 = new ArrayList<>(collect); + List<AiCompany> listById = this.getListById((collect1)); + map = listById.stream().collect(Collectors.toMap(AiCompany::getId, aiCompany -> aiCompany)); + } + + for (AiCompanyWorkflow aiCompanyWorkflow : records){ + if (map.containsKey(aiCompanyWorkflow.getCompanyId())){ + aiCompanyWorkflow.setCompanyName(map.get(aiCompanyWorkflow.getCompanyId()).getName()); + } + } + + } return pages; } -- Gitblit v1.9.1