From 3d537706cc01c444ee6bbd3a5f0cc3d7a63c15a1 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 22 Jan 2026 16:06:19 +0800
Subject: [PATCH] feat(ai): 添加AI产品状态变更前的完整性验证
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java | 97 ++++++++++++++++++++++++++++++++++++++++++++----
1 files changed, 88 insertions(+), 9 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
index 9ac7ab2..8d0fa7b 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiProductServiceImpl.java
@@ -3,10 +3,7 @@
import cc.mrbird.febs.ai.entity.*;
import cc.mrbird.febs.ai.mapper.AiProductMapper;
import cc.mrbird.febs.ai.req.AdminMoveChooseInfoDto;
-import cc.mrbird.febs.ai.service.AiProductCategoryService;
-import cc.mrbird.febs.ai.service.AiProductPointLinkService;
-import cc.mrbird.febs.ai.service.AiProductRoleLinkService;
-import cc.mrbird.febs.ai.service.AiProductService;
+import cc.mrbird.febs.ai.service.*;
import cc.mrbird.febs.ai.util.UUID;
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.entity.QueryRequest;
@@ -21,6 +18,7 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
import java.util.Date;
import java.util.List;
@@ -43,6 +41,7 @@
private final AiProductCategoryService aiProductCategoryService;
private final AiProductPointLinkService aiProductPointLinkService;
private final AiProductRoleLinkService aiProductRoleLinkService;
+ private final AiProductQuestionLinkService aiProductQuestionLinkService;
@Override
public AiProduct getById(String id) {
@@ -56,6 +55,9 @@
LambdaQueryWrapper<AiProduct> query = Wrappers.lambdaQuery(AiProduct.class);
if (StrUtil.isNotEmpty(dto.getProductCategoryId())){
query.eq(AiProduct::getProductCategoryId, dto.getProductCategoryId());
+ }
+ if (StrUtil.isNotEmpty(dto.getCompanyId())){
+ query.eq(AiProduct::getCompanyId, dto.getCompanyId());
}
query.ne(AiProduct::getState, 2);
query.orderByDesc(AiProduct::getHotState);
@@ -78,11 +80,36 @@
}
@Override
+ @Transactional
public FebsResponse changeState(String id, Integer type, Integer state) {
AiProduct entity = this.getById(id);
if(ObjectUtil.isNotNull(entity)){
if(1 == type){
+ if (1 == state){
+ List<AiProductPointLink> list = aiProductPointLinkService.selectListByQuery(
+ Wrappers.lambdaQuery(AiProductPointLink.class)
+ .eq(AiProductPointLink::getProductId, id)
+ );
+ if(CollUtil.isEmpty(list)){
+ return new FebsResponse().fail().message("请配置知识点");
+ }
+ List<AiProductRoleLink> list1 = aiProductRoleLinkService.selectListByQuery(
+ Wrappers.lambdaQuery(AiProductRoleLink.class)
+ .eq(AiProductRoleLink::getProductId, id)
+ );
+ if(CollUtil.isEmpty(list1)){
+ return new FebsResponse().fail().message("请配置AI陪练");
+ }
+ List<AiProductQuestionLink> list2 = aiProductQuestionLinkService.selectListByQuery(
+ Wrappers.lambdaQuery(AiProductQuestionLink.class)
+ .eq(AiProductQuestionLink::getProductId, id)
+ );
+ if(CollUtil.isEmpty(list2)){
+ return new FebsResponse().fail().message("请配置AI题目");
+ }
+ }
+
aiProductMapper.update(null,
Wrappers.lambdaUpdate(AiProduct.class)
.set(AiProduct::getState, state)
@@ -115,6 +142,7 @@
entity.setTarget(dto.getTarget());
entity.setDescription(dto.getDescription());
entity.setQuestionCount(dto.getQuestionCount());
+ entity.setTalkCnt(dto.getTalkCnt());
entity.setCreatedTime(new Date());
this.save(entity);
return new FebsResponse().success().message("操作成功");
@@ -137,6 +165,7 @@
.set(AiProduct::getTarget, dto.getTarget())
.set(AiProduct::getDescription, dto.getDescription())
.set(AiProduct::getQuestionCount, dto.getQuestionCount())
+ .set(AiProduct::getTalkCnt, dto.getTalkCnt())
.set(AiProduct::getUpdatedTime, new Date())
.eq(AiProduct::getId, id)
);
@@ -160,11 +189,13 @@
}
@Override
- public List<AiProduct> selectList() {
- return aiProductMapper.selectList(
- Wrappers.lambdaQuery(AiProduct.class)
- .ne(AiProduct::getState, 2)
- );
+ public List<AiProduct> selectList(String companyId) {
+ LambdaQueryWrapper<AiProduct> query = Wrappers.lambdaQuery(AiProduct.class);
+ if (StrUtil.isNotEmpty(companyId)){
+ query.eq(AiProduct::getCompanyId, companyId);
+ }
+ query.ne(AiProduct::getState, 2);
+ return aiProductMapper.selectList(query);
}
@Override
@@ -174,15 +205,18 @@
List<String> chooseIds = dto.getChooseIds();
AiProduct aiProduct = this.getById(chooseId);
if (ObjectUtil.isNotNull(aiProduct)) {
+ String companyId = aiProduct.getCompanyId();
aiProductPointLinkService.deleteByQuery(
Wrappers.lambdaQuery(AiProductPointLink.class)
.eq(AiProductPointLink::getProductId,chooseId)
+ .eq(AiProductPointLink::getCompanyId,companyId)
);
if(CollUtil.isNotEmpty(chooseIds)){
Date createdTime = new Date();
for (String item : chooseIds){
AiProductPointLink entity = new AiProductPointLink();
entity.setId(UUID.getSimpleUUIDString());
+ entity.setCompanyId(companyId);
entity.setProductId(chooseId);
entity.setProductPointId(item);
entity.setCreatedTime(createdTime);
@@ -200,15 +234,18 @@
List<String> chooseIds = dto.getChooseIds();
AiProduct aiProduct = this.getById(chooseId);
if (ObjectUtil.isNotNull(aiProduct)) {
+ String companyId = aiProduct.getCompanyId();
aiProductRoleLinkService.deleteByQuery(
Wrappers.lambdaQuery(AiProductRoleLink.class)
.eq(AiProductRoleLink::getProductId,chooseId)
+ .eq(AiProductRoleLink::getCompanyId,companyId)
);
if(CollUtil.isNotEmpty(chooseIds)){
Date createdTime = new Date();
for (String item : chooseIds){
AiProductRoleLink entity = new AiProductRoleLink();
entity.setId(UUID.getSimpleUUIDString());
+ entity.setCompanyId(companyId);
entity.setProductId(chooseId);
entity.setProductRoleId(item);
entity.setCreatedTime(createdTime);
@@ -218,4 +255,46 @@
}
return new FebsResponse().success().message("操作成功");
}
+
+ @Override
+ public FebsResponse productQuestionSet(AdminMoveChooseInfoDto dto) {
+ String chooseId = dto.getChooseId();
+ List<String> chooseIds = dto.getChooseIds();
+ AiProduct aiProduct = this.getById(chooseId);
+ if (ObjectUtil.isNotNull(aiProduct)) {
+ String companyId = aiProduct.getCompanyId();
+ aiProductQuestionLinkService.deleteByQuery(
+ Wrappers.lambdaQuery(AiProductQuestionLink.class)
+ .eq(AiProductQuestionLink::getProductId,chooseId)
+ .eq(AiProductQuestionLink::getCompanyId,companyId)
+ );
+ if(CollUtil.isNotEmpty(chooseIds)){
+ Date createdTime = new Date();
+ for (String item : chooseIds){
+ AiProductQuestionLink entity = new AiProductQuestionLink();
+ entity.setId(UUID.getSimpleUUIDString());
+ entity.setCompanyId(companyId);
+ entity.setProductId(chooseId);
+ entity.setProductQuestionId(item);
+ entity.setCreatedTime(createdTime);
+ aiProductQuestionLinkService.getBaseMapper().insert(entity);
+ }
+ }
+ }
+ return new FebsResponse().success().message("操作成功");
+ }
+
+ @Override
+ public List<AiProduct> listByCategory(AiProduct dto) {
+ LambdaQueryWrapper<AiProduct> query = Wrappers.lambdaQuery(AiProduct.class);
+ if (StrUtil.isNotEmpty(dto.getProductCategoryId())){
+ query.eq(AiProduct::getProductCategoryId, dto.getProductCategoryId());
+ }
+ if (StrUtil.isNotEmpty(dto.getCompanyId())){
+ query.eq(AiProduct::getCompanyId, dto.getCompanyId());
+ }
+ query.ne(AiProduct::getState, 2);
+ query.orderByAsc(AiProduct::getSort);
+ return aiProductMapper.selectList(query);
+ }
}
--
Gitblit v1.9.1