FastGPT/packages/service/core/chat/chatSchema.ts
Archer 2fea73bb68
perf: index (#6131)
* perf: index

* stop design doc

* perf: stop workflow;perf: mongo connection

* fix: ts

* mq export
2025-12-21 19:15:10 +08:00

205 lines
4.2 KiB
TypeScript

import { connectionMongo, getMongoModel } from '../../common/mongo';
const { Schema } = connectionMongo;
import { type ChatSchemaType } from '@fastgpt/global/core/chat/type.d';
import { ChatSourceEnum } from '@fastgpt/global/core/chat/constants';
import {
TeamCollectionName,
TeamMemberCollectionName
} from '@fastgpt/global/support/user/team/constant';
import { AppCollectionName } from '../app/schema';
import { chatCollectionName } from './constants';
import { AppVersionCollectionName } from '../app/version/schema';
const ChatSchema = new Schema({
chatId: {
type: String,
require: true
},
userId: {
type: Schema.Types.ObjectId,
ref: 'user'
},
teamId: {
type: Schema.Types.ObjectId,
ref: TeamCollectionName,
required: true
},
tmbId: {
type: Schema.Types.ObjectId,
ref: TeamMemberCollectionName,
required: true
},
appId: {
type: Schema.Types.ObjectId,
ref: AppCollectionName,
required: true
},
appVersionId: {
type: Schema.Types.ObjectId,
ref: AppVersionCollectionName
},
createTime: {
type: Date,
default: () => new Date()
},
updateTime: {
type: Date,
default: () => new Date()
},
title: {
type: String,
default: '历史记录'
},
customTitle: {
type: String,
default: ''
},
top: {
type: Boolean,
default: false
},
source: {
type: String,
required: true,
enum: Object.values(ChatSourceEnum)
},
sourceName: String,
shareId: {
type: String
},
outLinkUid: {
type: String
},
variableList: {
type: Array
},
welcomeText: {
type: String
},
variables: {
// variable value
type: Object,
default: {}
},
pluginInputs: Array,
metadata: {
//For special storage
type: Object,
default: {}
},
// Feedback count statistics (redundant fields for performance)
// Boolean flags for efficient filtering
hasGoodFeedback: Boolean,
hasBadFeedback: Boolean,
hasUnreadGoodFeedback: Boolean,
hasUnreadBadFeedback: Boolean,
deleteTime: {
type: Date,
default: null,
select: false
}
});
try {
ChatSchema.index({ appId: 1, tmbId: 1, outLinkUid: 1 });
ChatSchema.index({ chatId: 1 });
// get user history
ChatSchema.index({ tmbId: 1, appId: 1, deleteTime: 1, top: -1, updateTime: -1 });
// get share chat history
ChatSchema.index({ shareId: 1, outLinkUid: 1, updateTime: -1 });
// delete by appid; clear history; init chat; update chat; auth chat; get chat;
ChatSchema.index({ appId: 1, chatId: 1 });
/* get chat logs */
// 1. No feedback filter
ChatSchema.index({ teamId: 1, appId: 1, source: 1, tmbId: 1, deleteTime: 1, updateTime: -1 });
/* 反馈过滤的索引 */
// 2. Has good feedback filter
ChatSchema.index(
{
teamId: 1,
appId: 1,
source: 1,
tmbId: 1,
hasGoodFeedback: 1,
deleteTime: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasGoodFeedback: true,
deleteTime: null
}
}
);
// 3. Has bad feedback filter
ChatSchema.index(
{
teamId: 1,
appId: 1,
source: 1,
tmbId: 1,
hasBadFeedback: 1,
deleteTime: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasBadFeedback: true,
deleteTime: null
}
}
);
// 4. Has unread good feedback filter
ChatSchema.index(
{
teamId: 1,
appId: 1,
source: 1,
tmbId: 1,
hasUnreadGoodFeedback: 1,
deleteTime: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasUnreadGoodFeedback: true,
deleteTime: null
}
}
);
// 5. Has unread bad feedback filter
ChatSchema.index(
{
teamId: 1,
appId: 1,
source: 1,
tmbId: 1,
hasUnreadBadFeedback: 1,
deleteTime: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasUnreadBadFeedback: true,
deleteTime: null
}
}
);
// timer, clear history
ChatSchema.index({ updateTime: -1, teamId: 1 });
ChatSchema.index({ teamId: 1, updateTime: -1 });
} catch (error) {
console.log(error);
}
export const MongoChat = getMongoModel<ChatSchemaType>(chatCollectionName, ChatSchema);