文档版本: v1.0
创建日期: 2026-03-17
完整文档: feishu-assessment-integration-design.md
答案:当前使用默认知识库(用户的所有文件)
原因:在 feishu.service.ts 中调用 chatService.streamChat() 时,selectedFiles 和 selectedGroups 参数均为 undefined,导致搜索用户所有文件。
答案:通过自然语言命令触发测评功能
命令格式:
/assessment start [kbId|templateId] - 开始测评/assessment answer [answer] - 提交答案/assessment status - 查看状态/assessment result - 获取结果在 FeishuBot 实体中新增字段:
knowledgeBaseId: string; // 特定知识库ID
knowledgeGroupId: string; // 知识组ID
用户消息 → 命令解析器 → 测评服务 → 人才测评模块
↓
聊天服务(非测评消息)
1. 用户: /assessment start
2. 系统: 创建测评会话,发送第一个问题卡片
3. 用户: 回复答案
4. 系统: 评估答案,发送下一个问题
5. ... 循环直到测评完成
6. 系统: 发送测评结果报告
// feishu.service.ts
async processChatMessage(bot: FeishuBot, ...) {
let selectedFiles: string[] | undefined;
let selectedGroups: string[] | undefined;
if (bot.knowledgeBaseId) {
selectedFiles = await this.getFilesByKnowledgeBase(bot.knowledgeBaseId, ...);
} else if (bot.knowledgeGroupId) {
selectedGroups = [bot.knowledgeGroupId];
}
const stream = this.chatService.streamChat(
userMessage,
[],
userId,
llmModel,
language,
undefined,
selectedGroups, // 使用配置的知识组
selectedFiles, // 使用配置的知识库文件
// ...
);
}
// feishu-assessment.service.ts
async handleCommand(bot: FeishuBot, openId: string, message: string) {
const command = this.commandParser.parse(message);
if (!command) {
// 非测评命令,使用默认聊天
await this.feishuService.processChatMessage(bot, openId, '', message);
return;
}
switch (command.type) {
case AssessmentCommandType.START:
await this.startAssessment(bot, openId, command.parameters);
break;
case AssessmentCommandType.ANSWER:
await this.submitAnswer(bot, openId, command.parameters[0]);
break;
// ...
}
}
POST /feishu/bots
{
"appId": "cli_xxx",
"appSecret": "xxx",
"knowledgeBaseId": "kb_xxx", // 可选
"knowledgeGroupId": "group_xxx" // 可选
}
POST /feishu/assessment/start
{
"botId": "bot_xxx",
"openId": "ou_xxx",
"knowledgeBaseId": "kb_xxx",
"templateId": "tmpl_xxx"
}
userId 和 tenantIdserver/src/feishu/entities/feishu-assessment-session.entity.tsserver/src/feishu/dto/assessment-command.dto.tsserver/src/feishu/services/assessment-command.parser.tsserver/src/feishu/services/feishu-assessment.service.tsserver/src/migrations/XXXXXX-AddFeishuBotKnowledgeFields.tsserver/src/migrations/XXXXXX-CreateFeishuAssessmentSessionTable.tsserver/src/feishu/entities/feishu-bot.entity.tsserver/src/feishu/dto/create-bot.dto.tsserver/src/feishu/feishu.service.tsserver/src/feishu/feishu.module.ts| 问题 | 答案 |
|---|---|
| 飞书机器人当前对接哪个知识库? | 默认知识库(用户所有文件) |
| 如何配置特定知识库? | 在 FeishuBot 实体中设置 knowledgeBaseId 或 knowledgeGroupId |
| 如何与人才测评对接? | 通过 /assessment 命令触发测评功能 |
| 实施周期 | 5-7 天 |