mirror of
https://github.com/labring/FastGPT.git
synced 2025-12-25 20:02:47 +00:00
* perf: zod with app log (#6083) * perf: safe decode * perf: zod with app log * fix: text * remove log * rename field * refactor: improve like/dislike interaction (#6080) * refactor: improve like/dislike interaction * button style & merge status * perf * fix * i18n * feedback ui * format * api optimize * openapi * read status --------- Co-authored-by: archer <545436317@qq.com> * perf: remove empty chat * perf: delete resource tip * fix: confirm * feedback filter * fix: ts * perf: linker scroll * perf: feedback ui * fix: plugin file input store * fix: max tokens * update comment * fix: condition value type * fix feedback (#6095) * fix feedback * text * list * fix: versionid --------- Co-authored-by: archer <545436317@qq.com> * fix: chat setting render;export logs filter * add test * perf: log list api * perf: redirect check * perf: log list * create ui * create ui --------- Co-authored-by: heheer <heheer@sealos.io>
190 lines
3.8 KiB
TypeScript
190 lines
3.8 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
|
|
});
|
|
|
|
try {
|
|
ChatSchema.index({ appId: 1, tmbId: 1, outLinkUid: 1 });
|
|
|
|
ChatSchema.index({ chatId: 1 });
|
|
// get user history
|
|
ChatSchema.index({ tmbId: 1, appId: 1, top: -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, updateTime: -1 });
|
|
|
|
/* 反馈过滤的索引 */
|
|
// 2. Has good feedback filter
|
|
ChatSchema.index(
|
|
{
|
|
teamId: 1,
|
|
appId: 1,
|
|
source: 1,
|
|
tmbId: 1,
|
|
hasGoodFeedback: 1,
|
|
updateTime: -1
|
|
},
|
|
{
|
|
partialFilterExpression: {
|
|
hasGoodFeedback: true
|
|
}
|
|
}
|
|
);
|
|
// 3. Has bad feedback filter
|
|
ChatSchema.index(
|
|
{
|
|
teamId: 1,
|
|
appId: 1,
|
|
source: 1,
|
|
tmbId: 1,
|
|
hasBadFeedback: 1,
|
|
updateTime: -1
|
|
},
|
|
{
|
|
partialFilterExpression: {
|
|
hasBadFeedback: true
|
|
}
|
|
}
|
|
);
|
|
// 4. Has unread good feedback filter
|
|
ChatSchema.index(
|
|
{
|
|
teamId: 1,
|
|
appId: 1,
|
|
source: 1,
|
|
tmbId: 1,
|
|
hasUnreadGoodFeedback: 1,
|
|
updateTime: -1
|
|
},
|
|
{
|
|
partialFilterExpression: {
|
|
hasUnreadGoodFeedback: true
|
|
}
|
|
}
|
|
);
|
|
// 5. Has unread bad feedback filter
|
|
ChatSchema.index(
|
|
{
|
|
teamId: 1,
|
|
appId: 1,
|
|
source: 1,
|
|
tmbId: 1,
|
|
hasUnreadBadFeedback: 1,
|
|
updateTime: -1
|
|
},
|
|
{
|
|
partialFilterExpression: {
|
|
hasUnreadBadFeedback: true
|
|
}
|
|
}
|
|
);
|
|
|
|
// get share chat history
|
|
ChatSchema.index({ shareId: 1, outLinkUid: 1, updateTime: -1 });
|
|
|
|
// timer, clear history
|
|
ChatSchema.index({ teamId: 1, updateTime: -1 });
|
|
} catch (error) {
|
|
console.log(error);
|
|
}
|
|
|
|
export const MongoChat = getMongoModel<ChatSchemaType>(chatCollectionName, ChatSchema);
|