mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-16 08:01:18 +00:00

* add dynamic inputRender (#5127) * dynamic input component * fix * fix * fix * perf: dynamic render input * update doc * perf: error catch * num input ui * fix form render (#5177) * perf: i18n check * add log * doc * Sync dataset (#5181) * perf: api dataset create (#5047) * Sync dataset (#5120) * add * wait * restructure dataset sync, update types and APIs, add sync hints, and remove legacy logic * feat: add function to retrieve real file ID from third-party doc library and rename team permission check function for clarity * fix come console * refactor: rename team dataset limit check functions for clarity, update API dataset sync limit usage, and rename root directory to "ROOT_FOLDER" * frat: update sync dataset login * fix delete.ts * feat: update pnpm-lock.yaml to include bullmq, fix comments in api.d.ts and type.d.ts, rename API file ID field, optimize dataset sync logic, and add website sync feature with related APIs * feat: update CollectionCard to support site dataset sync, add API root ID constant and init sync API * feat: add RootCollectionId constant to replace hardcoded root ID --------- Co-authored-by: dreamer6680 <146868355@qq.com> * perf: code * feat: update success message for dataset sync, revise related i18n texts, and optimize file selection logic (#5166) Co-authored-by: dreamer6680 <146868355@qq.com> * perf: select file * Sync dataset (#5180) * feat: update success message for dataset sync, revise related i18n texts, and optimize file selection logic * fix: make listfile function return rawid string --------- Co-authored-by: dreamer6680 <146868355@qq.com> * init sh * fix: ts --------- Co-authored-by: dreamer6680 <1468683855@qq.com> Co-authored-by: dreamer6680 <146868355@qq.com> * update doc * i18n --------- Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: dreamer6680 <1468683855@qq.com> Co-authored-by: dreamer6680 <146868355@qq.com>
131 lines
4.1 KiB
TypeScript
131 lines
4.1 KiB
TypeScript
import { getTeamPlanStatus, getTeamStandPlan, getTeamPoints } from '../../support/wallet/sub/utils';
|
|
import { MongoApp } from '../../core/app/schema';
|
|
import { MongoDataset } from '../../core/dataset/schema';
|
|
import { DatasetTypeEnum } from '@fastgpt/global/core/dataset/constants';
|
|
import { TeamErrEnum } from '@fastgpt/global/common/error/code/team';
|
|
import { SystemErrEnum } from '@fastgpt/global/common/error/code/system';
|
|
import { AppTypeEnum } from '@fastgpt/global/core/app/constants';
|
|
import { MongoTeamMember } from '../user/team/teamMemberSchema';
|
|
import { TeamMemberStatusEnum } from '@fastgpt/global/support/user/team/constant';
|
|
import { getVectorCountByTeamId } from '../../common/vectorDB/controller';
|
|
|
|
export const checkTeamAIPoints = async (teamId: string) => {
|
|
if (!global.subPlans?.standard) return;
|
|
|
|
const { totalPoints, usedPoints } = await getTeamPoints({ teamId });
|
|
|
|
if (usedPoints >= totalPoints) {
|
|
return Promise.reject(TeamErrEnum.aiPointsNotEnough);
|
|
}
|
|
|
|
return {
|
|
totalPoints,
|
|
usedPoints
|
|
};
|
|
};
|
|
|
|
export const checkTeamMemberLimit = async (teamId: string, newCount: number) => {
|
|
const [{ standardConstants }, memberCount] = await Promise.all([
|
|
getTeamStandPlan({
|
|
teamId
|
|
}),
|
|
MongoTeamMember.countDocuments({
|
|
teamId,
|
|
status: { $ne: TeamMemberStatusEnum.leave }
|
|
})
|
|
]);
|
|
|
|
if (standardConstants && newCount + memberCount > standardConstants.maxTeamMember) {
|
|
return Promise.reject(TeamErrEnum.teamOverSize);
|
|
}
|
|
};
|
|
|
|
export const checkTeamAppLimit = async (teamId: string, amount = 1) => {
|
|
const [{ standardConstants }, appCount] = await Promise.all([
|
|
getTeamStandPlan({ teamId }),
|
|
MongoApp.countDocuments({
|
|
teamId,
|
|
type: {
|
|
$in: [AppTypeEnum.simple, AppTypeEnum.workflow, AppTypeEnum.plugin, AppTypeEnum.tool]
|
|
}
|
|
})
|
|
]);
|
|
|
|
if (standardConstants && appCount + amount >= standardConstants.maxAppAmount) {
|
|
return Promise.reject(TeamErrEnum.appAmountNotEnough);
|
|
}
|
|
|
|
// System check
|
|
if (global?.licenseData?.maxApps && typeof global?.licenseData?.maxApps === 'number') {
|
|
const totalApps = await MongoApp.countDocuments({
|
|
type: {
|
|
$in: [AppTypeEnum.simple, AppTypeEnum.workflow, AppTypeEnum.plugin, AppTypeEnum.tool]
|
|
}
|
|
});
|
|
if (totalApps >= global.licenseData.maxApps) {
|
|
return Promise.reject(SystemErrEnum.licenseAppAmountLimit);
|
|
}
|
|
}
|
|
};
|
|
|
|
export const checkDatasetIndexLimit = async ({
|
|
teamId,
|
|
insertLen = 0
|
|
}: {
|
|
teamId: string;
|
|
insertLen?: number;
|
|
}) => {
|
|
const [{ standardConstants, totalPoints, usedPoints, datasetMaxSize }, usedDatasetIndexSize] =
|
|
await Promise.all([getTeamPlanStatus({ teamId }), getVectorCountByTeamId(teamId)]);
|
|
|
|
if (!standardConstants) return;
|
|
|
|
if (usedDatasetIndexSize + insertLen >= datasetMaxSize) {
|
|
return Promise.reject(TeamErrEnum.datasetSizeNotEnough);
|
|
}
|
|
|
|
if (usedPoints >= totalPoints) {
|
|
return Promise.reject(TeamErrEnum.aiPointsNotEnough);
|
|
}
|
|
return;
|
|
};
|
|
|
|
export const checkTeamDatasetLimit = async (teamId: string) => {
|
|
const [{ standardConstants }, datasetCount] = await Promise.all([
|
|
getTeamStandPlan({ teamId }),
|
|
MongoDataset.countDocuments({
|
|
teamId,
|
|
type: { $ne: DatasetTypeEnum.folder }
|
|
})
|
|
]);
|
|
|
|
// User check
|
|
if (standardConstants && datasetCount >= standardConstants.maxDatasetAmount) {
|
|
return Promise.reject(TeamErrEnum.datasetAmountNotEnough);
|
|
}
|
|
|
|
// System check
|
|
if (global?.licenseData?.maxDatasets && typeof global?.licenseData?.maxDatasets === 'number') {
|
|
const totalDatasets = await MongoDataset.countDocuments({
|
|
type: { $ne: DatasetTypeEnum.folder }
|
|
});
|
|
if (totalDatasets >= global.licenseData.maxDatasets) {
|
|
return Promise.reject(SystemErrEnum.licenseDatasetAmountLimit);
|
|
}
|
|
}
|
|
// Open source check
|
|
if (!global.feConfigs.isPlus && datasetCount >= 30) {
|
|
return Promise.reject(SystemErrEnum.communityVersionNumLimit);
|
|
}
|
|
};
|
|
|
|
export const checkTeamDatasetSyncPermission = async (teamId: string) => {
|
|
const { standardConstants } = await getTeamStandPlan({
|
|
teamId
|
|
});
|
|
|
|
if (standardConstants && !standardConstants?.permissionWebsiteSync) {
|
|
return Promise.reject(TeamErrEnum.websiteSyncNotEnough);
|
|
}
|
|
};
|