mirror of
https://github.com/labring/FastGPT.git
synced 2025-12-25 20:02:47 +00:00
Some checks failed
Build FastGPT images in Personal warehouse / get-vars (push) Has been cancelled
Build FastGPT images in Personal warehouse / build-fastgpt-images (map[arch:amd64 runs-on:ubuntu-24.04]) (push) Has been cancelled
Build FastGPT images in Personal warehouse / build-fastgpt-images (map[arch:arm64 runs-on:ubuntu-24.04-arm]) (push) Has been cancelled
Build FastGPT images in Personal warehouse / release-fastgpt-images (push) Has been cancelled
* activity points * modal * ui * fix * pref: zod schema * perf: ad api with zod * perf: plan year switch * perf: plan * i18n * fix: hook * fix: activity checker * fix: i18n * fix clear token * fix * back * can close modal in pay * ad token * rename * fix * total points * eng i18n --------- Co-authored-by: archer <545436317@qq.com>
104 lines
2.4 KiB
TypeScript
104 lines
2.4 KiB
TypeScript
/*
|
|
user sub plan
|
|
1. type=standard: There will only be 1, and each team will have one
|
|
2. type=extraDatasetSize/extraPoints: Can buy multiple
|
|
*/
|
|
import { connectionMongo, getMongoModel } from '../../../common/mongo';
|
|
const { Schema } = connectionMongo;
|
|
import { TeamCollectionName } from '@fastgpt/global/support/user/team/constant';
|
|
import {
|
|
StandardSubLevelEnum,
|
|
SubModeEnum,
|
|
SubTypeEnum
|
|
} from '@fastgpt/global/support/wallet/sub/constants';
|
|
import type { TeamSubSchemaType } from '@fastgpt/global/support/wallet/sub/type';
|
|
|
|
export const subCollectionName = 'team_subscriptions';
|
|
|
|
const SubSchema = new Schema({
|
|
teamId: {
|
|
type: Schema.Types.ObjectId,
|
|
ref: TeamCollectionName,
|
|
required: true
|
|
},
|
|
type: {
|
|
type: String,
|
|
enum: Object.values(SubTypeEnum),
|
|
required: true
|
|
},
|
|
startTime: {
|
|
type: Date,
|
|
default: () => new Date()
|
|
},
|
|
expiredTime: {
|
|
type: Date,
|
|
required: true
|
|
},
|
|
|
|
// standard sub
|
|
currentMode: {
|
|
type: String,
|
|
enum: Object.values(SubModeEnum)
|
|
},
|
|
nextMode: {
|
|
type: String,
|
|
enum: Object.values(SubModeEnum)
|
|
},
|
|
currentSubLevel: {
|
|
type: String,
|
|
enum: Object.values(StandardSubLevelEnum)
|
|
},
|
|
nextSubLevel: {
|
|
type: String,
|
|
enum: Object.values(StandardSubLevelEnum)
|
|
},
|
|
maxTeamMember: Number,
|
|
maxApp: Number,
|
|
maxDataset: Number,
|
|
|
|
// custom level configurations
|
|
requestsPerMinute: Number,
|
|
chatHistoryStoreDuration: Number,
|
|
maxDatasetSize: Number,
|
|
websiteSyncPerDataset: Number,
|
|
appRegistrationCount: Number,
|
|
auditLogStoreDuration: Number,
|
|
ticketResponseTime: Number,
|
|
customDomain: Number,
|
|
|
|
// stand sub and extra points sub. Plan total points
|
|
totalPoints: Number,
|
|
// plan surplus points
|
|
surplusPoints: Number,
|
|
|
|
// extra dataset size
|
|
currentExtraDatasetSize: Number
|
|
});
|
|
|
|
try {
|
|
// Get plan by expiredTime
|
|
SubSchema.index({ expiredTime: -1, currentSubLevel: 1 });
|
|
|
|
// Get team plan
|
|
SubSchema.index({ teamId: 1, type: 1, expiredTime: -1 });
|
|
// timer task. Get standard plan;Get free plan;Clear expired extract plan
|
|
SubSchema.index({ type: 1, expiredTime: -1, currentSubLevel: 1 });
|
|
|
|
// 修改后的唯一索引
|
|
SubSchema.index(
|
|
{
|
|
teamId: 1,
|
|
type: 1,
|
|
currentSubLevel: 1
|
|
},
|
|
{
|
|
unique: true,
|
|
partialFilterExpression: { type: SubTypeEnum.standard }
|
|
}
|
|
);
|
|
} catch (error) {
|
|
console.log(error);
|
|
}
|
|
|
|
export const MongoTeamSub = getMongoModel<TeamSubSchemaType>(subCollectionName, SubSchema);
|