From ac4d9f32276cebd60050afd3ca96ad7417bc5861 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Thu, 23 Oct 2025 10:43:29 +0800
Subject: [PATCH] feat(ai): 新增产品解锁和依赖关系功能模块
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java | 28 ++++++++++++++++++++++++++++
1 files changed, 28 insertions(+), 0 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 1be9722..1bae742 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
@@ -6,12 +6,16 @@
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.KnowledgeBaseUtil;
import cc.mrbird.febs.ai.util.UUID;
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.common.exception.FebsException;
import cc.mrbird.febs.common.utils.ShareCodeUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ObjectUtil;
+import com.aliyun.bailian20231229.Client;
+import com.aliyun.bailian20231229.models.CreateIndexResponse;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
@@ -20,6 +24,7 @@
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
import java.util.*;
import java.util.stream.Collectors;
@@ -45,6 +50,7 @@
}
@Override
+ @Transactional
public FebsResponse add(AiCompany dto) {
Date createTime = new Date();
AiCompany entity = new AiCompany();
@@ -63,6 +69,28 @@
this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.REPORT.getCode(),null,createTime);
this.addWorkflow(entity.getId(), LlmApplicationAppIdEnum.ADMIN_QUESTION.getCode(),null,createTime);
+ String categoryId = "";
+ try {
+ categoryId = KnowledgeBaseUtil.AddCategory(entity.getName(), null);
+ } catch (Exception e) {
+ throw new FebsException("初始化分类失败");
+ }
+
+ String knowledgeId = "";
+ try {
+ String name = entity.getName();
+ String fileId = "file_b7d0a5b2df1745b9bfb7402f5fe1054f_12629554";
+ knowledgeId = KnowledgeBaseUtil.createKnowledgeBase(fileId, name);
+ } catch (Exception e) {
+ throw new FebsException("初始化知识库失败");
+ }
+
+ this.update(null,
+ Wrappers.lambdaUpdate(AiCompany.class)
+ .set(AiCompany::getKnowledgeId, knowledgeId)
+ .set(AiCompany::getCategoryId, categoryId)
+ .eq(AiCompany::getId, entity.getId()));
+
return new FebsResponse().success().message("操作成功");
}
--
Gitblit v1.9.1