From 451101e29d1d48a7ed06b6b31fe3f6bdda5dd88a Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 29 Sep 2025 15:45:51 +0800
Subject: [PATCH] feat(ai): 新增公司知识库初始化功能

---
 src/main/java/cc/mrbird/febs/ai/service/impl/AiCompanyServiceImpl.java |   64 +++++++++++++++++++++++++++++--
 1 files changed, 59 insertions(+), 5 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 5a1a242..37f0506 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,14 +2,20 @@
 
 import cc.mrbird.febs.ai.entity.AiCompany;
 import cc.mrbird.febs.ai.entity.AiCompanyWorkflow;
+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.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;
@@ -18,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;
@@ -43,23 +50,60 @@
     }
 
     @Override
+    @Transactional
     public FebsResponse add(AiCompany dto) {
         Date createTime = new Date();
         AiCompany entity = new AiCompany();
         entity.setId(UUID.getSimpleUUIDString());
         entity.setName(dto.getName());
+        entity.setCode(ShareCodeUtil.toSerialCode(1L));
         entity.setCreatedTime(createTime);
         this.baseMapper.insert( entity);
 
 
 
-        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);
+
+        String categoryId = "";
+        try {
+            categoryId = KnowledgeBaseUtil.AddCategory(entity.getName(), null);
+        } catch (Exception e) {
+            throw new FebsException("初始化分类失败");
+        }
+
+        String knowledgeId = "";
+        try {
+            Client client = KnowledgeBaseUtil.createClient();
+            String workspaceId = KnowledgeBaseUtil.WORKSPACE_ID;
+            String name = entity.getName();
+            String sourceType = "DATA_CENTER_FILE";
+            String structureType = "unstructured";
+            String sinkType = "DEFAULT";
+            String fileId = "file_b7d0a5b2df1745b9bfb7402f5fe1054f_12629554";
+            CreateIndexResponse indexResponse = KnowledgeBaseUtil.createIndex(client, workspaceId, fileId, name, structureType, sourceType, sinkType);
+            knowledgeId = indexResponse.getBody().getData().getId();
+        } 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("操作成功");
+    }
+
+    public static void main(String[] args) {
+        for (int i = 0; i < 10; i++){
+            System.out.println(ShareCodeUtil.toSerialCode(1L));
+        }
     }
 
     @Override
@@ -92,6 +136,16 @@
     }
 
     @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);

--
Gitblit v1.9.1