mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-18 17:51:24 +00:00

* Dataset collection forbid (#1885) * perf: tool call support same id * feat: collection forbid * feat: collection forbid * Inheritance Permission for apps (#1897) * feat: app schema define chore: references of authapp * feat: authApp method inheritance * feat: create and update api * feat: update * feat: inheritance Permission controller for app. * feat: abstract version of inheritPermission * feat: ancestorId for apps * chore: update app * fix: inheritPermission abstract version * feat: update folder defaultPermission * feat: app update api * chore: inheritance frontend * chore: app list api * feat: update defaultPermission in app deatil * feat: backend api finished * feat: app inheritance permission fe * fix: app update defaultpermission causes collaborator miss * fix: ts error * chore: adjust the codes * chore: i18n chore: i18n * chore: fe adjust and i18n * chore: adjust the code * feat: resume api; chore: rewrite update api and inheritPermission methods * chore: something * chore: fe code adjusting * feat: frontend adjusting * chore: fe code adjusting * chore: adjusting the code * perf: fe loading * format * Inheritance fix (#1908) * fix: SlideCard * fix: authapp did not return parent app for inheritance app * fix: fe adjusting * feat: fe adjusing * perf: inherit per ux * doc * fix: ts errors (#1916) * perf: inherit permission * fix: permission inherit * Workflow type (#1938) * perf: workflow type tmp workflow perf: workflow type feat: custom field config * perf: dynamic input * perf: node classify * perf: node classify * perf: node classify * perf: node classify * fix: workflow custom input * feat: text editor and customFeedback move to basic nodes * feat: community system plugin * fix: ts * feat: exprEval plugin * perf: workflow type * perf: plugin important * fix: default templates * perf: markdown hr css * lock * perf: fetch url * perf: new plugin version * fix: chat histories update * fix: collection paths invalid * perf: app card ui --------- Co-authored-by: Finley Ge <32237950+FinleyGe@users.noreply.github.com>
127 lines
2.5 KiB
TypeScript
127 lines
2.5 KiB
TypeScript
import { AppTypeEnum } from '@fastgpt/global/core/app/constants';
|
|
import { connectionMongo, type Model } from '../../common/mongo';
|
|
const { Schema, model, models } = connectionMongo;
|
|
import type { AppSchema as AppType } from '@fastgpt/global/core/app/type.d';
|
|
import {
|
|
TeamCollectionName,
|
|
TeamMemberCollectionName
|
|
} from '@fastgpt/global/support/user/team/constant';
|
|
import { AppDefaultPermissionVal } from '@fastgpt/global/support/permission/app/constant';
|
|
import { getPermissionSchema } from '@fastgpt/global/support/permission/utils';
|
|
|
|
export const AppCollectionName = 'apps';
|
|
|
|
export const chatConfigType = {
|
|
welcomeText: String,
|
|
variables: Array,
|
|
questionGuide: Boolean,
|
|
ttsConfig: Object,
|
|
whisperConfig: Object,
|
|
scheduledTriggerConfig: Object,
|
|
chatInputGuide: Object
|
|
};
|
|
|
|
const AppSchema = new Schema({
|
|
parentId: {
|
|
type: Schema.Types.ObjectId,
|
|
ref: AppCollectionName,
|
|
default: null
|
|
},
|
|
teamId: {
|
|
type: Schema.Types.ObjectId,
|
|
ref: TeamCollectionName,
|
|
required: true
|
|
},
|
|
tmbId: {
|
|
type: Schema.Types.ObjectId,
|
|
ref: TeamMemberCollectionName,
|
|
required: true
|
|
},
|
|
name: {
|
|
type: String,
|
|
required: true
|
|
},
|
|
type: {
|
|
type: String,
|
|
default: AppTypeEnum.workflow,
|
|
enum: Object.values(AppTypeEnum)
|
|
},
|
|
version: {
|
|
type: String,
|
|
enum: ['v1', 'v2']
|
|
},
|
|
avatar: {
|
|
type: String,
|
|
default: '/icon/logo.svg'
|
|
},
|
|
intro: {
|
|
type: String,
|
|
default: ''
|
|
},
|
|
updateTime: {
|
|
type: Date,
|
|
default: () => new Date()
|
|
},
|
|
|
|
// role and auth
|
|
teamTags: {
|
|
type: [String]
|
|
},
|
|
|
|
// save app(Not publish)
|
|
modules: {
|
|
type: Array,
|
|
default: []
|
|
},
|
|
edges: {
|
|
type: Array,
|
|
default: []
|
|
},
|
|
chatConfig: {
|
|
type: chatConfigType
|
|
},
|
|
// plugin config
|
|
pluginData: {
|
|
type: {
|
|
nodeVersion: String,
|
|
pluginUniId: String,
|
|
apiSchemaStr: String, // http plugin
|
|
customHeaders: String // http plugin
|
|
}
|
|
},
|
|
|
|
scheduledTriggerConfig: {
|
|
cronString: {
|
|
type: String
|
|
},
|
|
timezone: {
|
|
type: String
|
|
},
|
|
defaultPrompt: {
|
|
type: String
|
|
}
|
|
},
|
|
scheduledTriggerNextTime: {
|
|
type: Date
|
|
},
|
|
|
|
inited: {
|
|
type: Boolean
|
|
},
|
|
|
|
...getPermissionSchema(AppDefaultPermissionVal)
|
|
});
|
|
|
|
try {
|
|
AppSchema.index({ updateTime: -1 });
|
|
AppSchema.index({ teamId: 1, type: 1 });
|
|
AppSchema.index({ scheduledTriggerConfig: 1, intervalNextTime: -1 });
|
|
} catch (error) {
|
|
console.log(error);
|
|
}
|
|
|
|
export const MongoApp: Model<AppType> =
|
|
models[AppCollectionName] || model(AppCollectionName, AppSchema);
|
|
|
|
MongoApp.syncIndexes();
|