M7-01 P0 | Prisma ChatSession 新增 scopeType scopeId parentKnowledgeBaseId #79
Closed
opened 2026-06-06 16:21:46 +08:00 by wangdl
·
1 comment
Labels
Clear labels
area:activity
活动/统计
area:admin
管理后台
area:admin-api
area:ai
AI/RAG
area:ai-runtime
AI Runtime / AI 分析体系相关
area:analytics
area:api
API 接口
area:auth
认证与授权
area:cos
对象存储
area:database
数据库/Migration
area:import
文件导入/解析
area:knowledge
知识库/知识点
area:learning-info
area:learning-session
area:quiz
测验/自测
area:reading-event
area:reading-progress
area:review
复习系统
area:security
安全相关
audit:api-admin-info
audit:api-info
audit:planned
已完成宏观规划,尚未代码审查
audit:reviewed
blocked-by:api-info-aggregation
blocked-by:api-info-core
blocked-by:api-info-ops
blocked-by:api-info-schema
blocked-by:processor
blocked-by:schema
priority:p0
最高优先级,阻塞发布
priority:p1
高优先级,里程碑必需
priority:p2
中优先级,后续版本
repo:api
API 仓库 Issue
status:blocked
被阻塞
status:done
已完成
status:partial
status:todo
type:aggregation
type:bug
缺陷修复
type:design
设计
type:docs
文档
type:feature
新功能
type:migration
type:refactor
重构
type:test
work:admin-api
work:aggregation
work:api
work:artifact
题目/卡片产物
work:audit
work:circuit-breaker
熔断
work:contract
work:design
架构/协议设计工作
work:docs
work:export
work:extend-existing
work:internal-api
Runtime 内部接口
work:job
Job 调度相关
work:new-module
work:new-table
work:ops
work:query
work:quota
额度/限流
work:schema
Prisma Schema 设计
work:security
work:service
Service 层实现
work:snapshot
Snapshot 构建
work:test
No Label
Milestone
No items
No Milestone
M7:ChatScope 会话系统 — 学习对象绑定的上下文会话
Projects
Clear projects
No project
No Assignees
Notifications
Due Date
No due date set.
Dependencies
No dependencies set.
Reference: wangdl/api-server#79
Reference in New Issue
Block a user
Blocking a user prevents them from interacting with repositories, such as opening or commenting on pull requests or issues. Learn more about blocking a user.
No description provided.
Delete Branch "%!s()"
Deleting a branch is permanent. Although the deleted branch may continue to exist for a short time before it actually gets removed, it CANNOT be undone in most cases. Continue?
完成 ✅
Prisma Schema 变更 (
prisma/schema.prisma)ChatSession — 新增 10 个字段 + 4 个索引:
scopeTypeString @default("knowledge_base")scopeIdString?parentKnowledgeBaseIdString?createdFromString @default("legacy_migration")isPinnedBoolean @default(false)isArchivedBoolean @default(false)isDeletedBoolean @default(false)modelModeString @default("normal")modelIdString?lastMessageAtDateTime?ChatMessage — 新增:
scopeSnapshotJson? — 记录消息创建时的 scope 快照ChatCitation — 新增:
lineStartInt?lineEndInt?Service 层变更 (
rag-chat.service.ts)createSession— 接受CreateSessionParams(scopeType + scopeId + parentKnowledgeBaseId + createdFrom)listSessions— 支持 scopeType/scopeId/parentKnowledgeBaseId 过滤sendMessage/sendMessageStream— 存储 scopeSnapshot, 使用 loadContextByScopeloadContextByScope— 按 scope 类型检索 (material→sourceRef, item→精确id, kb→全库)updateSession— PATCH 端点 (title/isPinned/isArchived/modelMode),scope 字段不可修改deleteSession— 软删除 (isDeleted=true)Controller 变更 (
rag-chat.controller.ts)POST /sessions— 接受 scopeType/scopeId/parentKnowledgeBaseId/createdFromGET /sessions— 新增 scopeType/scopeId/parentKnowledgeBaseId query paramsPATCH /sessions/:id— 新端点DELETE /sessions/:id— 软删除注意
npx prisma migrate dev --name add_chat_scope_fields完成情况
交付物
1. Prisma Schema (
prisma/schema.prisma)ChatSession 模型新增 10 个字段:
新增 4 个索引:
@@index([userId, scopeType, scopeId])— open-or-create 核心查询@@index([userId, parentKnowledgeBaseId])— 知识库内会话列表@@index([userId, isDeleted])— 排除已删除@@index([lastMessageAt])— 时间排序保留旧字段
knowledgeBaseId和knowledgeItemIds,迁移后移除。2. Service 层 (
src/modules/rag-chat/rag-chat.service.ts)createSession(userId, CreateSessionParams)— 接受 scopeType/scopeId/parentKnowledgeBaseId/createdFrom,校验 scopeType 合法性和 scopeId 必填性deriveParentKbId()— 从 scope 推导 parentKnowledgeBaseIdlistSessions()— 支持 scopeType+scopeId 精确过滤、parentKnowledgeBaseId 知识库过滤、分页3. Controller 层 (
src/modules/rag-chat/rag-chat.controller.ts)POST /sessions— 接受 scopeType/scopeId/parentKnowledgeBaseId/createdFrom/titleGET /sessions— 新增 scopeType/scopeId/parentKnowledgeBaseId/page/limit query paramsPATCH /sessions/:id— 新端点,更新 title/isPinned/isArchived/modelMode/modelIdDELETE /sessions/:id— 改为软删除 (isDeleted=true)注意事项
npx prisma migrate dev --name add_chat_scope_fields涉及文件