Files
FastGPT/packages/service/core/chat/chatSchema.ts
T
Archer f7b64f25b1 V4.14.9 features (#6602)
* fix: image read and json error (Agent) (#6502)

* fix:
1.image read
2.JSON parsing error

* dataset cite and pause

* perf: plancall second parse

* add test

---------

Co-authored-by: archer <545436317@qq.com>

* master message

* remove invalid code

* fix: sandbox download file

* update lock

* sub set

* i18n

* perf: system forbid sandbox

* fix: i18n; next config

* fix: authchat uid

* update i18n

* perf: check exists

* stop in tool

* stop in tool

* fix: chat

* update action

* doc

* deploy doc

---------

Co-authored-by: YeYuheng <57035043+YYH211@users.noreply.github.com>
2026-03-22 17:58:45 +08:00

224 lines
4.6 KiB
TypeScript

import { connectionMongo, getMongoModel } from '../../common/mongo';
import { getLogger, LogCategories } from '../../common/logger';
const { Schema } = connectionMongo;
import { type ChatSchemaType } from '@fastgpt/global/core/chat/type';
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
},
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,
// Error count (redundant field for performance)
errorCount: {
type: Number,
default: 0
},
searchKey: String,
deleteTime: {
type: Date,
default: null,
select: false
},
/** @deprecated */
userId: Schema.Types.ObjectId
});
try {
ChatSchema.index({ chatId: 1 });
// Delete by appid; init chat; update chat; auth chat;
ChatSchema.index({ appId: 1, chatId: 1 }, { unique: true });
// Clear history(share),Init 4121
ChatSchema.index(
{ appId: 1, outLinkUid: 1, tmbId: 1 },
{
partialFilterExpression: {
outLinkUid: { $exists: true }
}
}
);
// 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 },
{
partialFilterExpression: {
shareId: { $exists: true }
}
}
);
/* get chat logs */
// 1. Common get
ChatSchema.index({ appId: 1, updateTime: -1 });
// Get history(tmbId)
ChatSchema.index({ appId: 1, tmbId: 1, updateTime: -1 });
// clearHistory(API)
ChatSchema.index({ appId: 1, source: 1, tmbId: 1, updateTime: -1 });
/* 反馈过滤的索引 */
// 2. Has good feedback filter
ChatSchema.index(
{
appId: 1,
hasGoodFeedback: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasGoodFeedback: true
}
}
);
// Has bad feedback filter
ChatSchema.index(
{
appId: 1,
hasBadFeedback: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasBadFeedback: true
}
}
);
// 3. Has unread good feedback filter
ChatSchema.index(
{
appId: 1,
hasUnreadGoodFeedback: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasUnreadGoodFeedback: true
}
}
);
// Has unread bad feedback filter
ChatSchema.index(
{
appId: 1,
hasUnreadBadFeedback: 1,
updateTime: -1
},
{
partialFilterExpression: {
hasUnreadBadFeedback: true
}
}
);
// Has error filter
ChatSchema.index(
{
appId: 1,
errorCount: 1,
updateTime: -1
},
{
partialFilterExpression: {
errorCount: { $gt: 0 }
}
}
);
// timer, clear history
ChatSchema.index({ updateTime: -1, teamId: 1 });
ChatSchema.index({ teamId: 1, updateTime: -1 });
} catch (error) {
const logger = getLogger(LogCategories.INFRA.MONGO);
logger.error('Failed to build chat indexes', { error });
}
export const MongoChat = getMongoModel<ChatSchemaType>(chatCollectionName, ChatSchema);