mirror of
https://github.com/labring/FastGPT.git
synced 2025-10-15 23:55:36 +00:00

* feat: workflow catch error (#5220) * feat: error catch * feat: workflow catch error * perf: add catch error to node * feat: system tool error catch * catch error * fix: ts * update doc * perf: training queue code (#5232) * doc * perf: training queue code * Feat: 优化错误提示与重试逻辑 (#5192) * feat: 批量重试异常数据 & 报错信息国际化 - 新增“全部重试”按钮,支持批量重试所有训练异常数据 - 报错信息支持国际化,常见错误自动映射为 i18n key - 相关文档和 i18n 资源已同步更新 * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism * feat: add retry_failed i18n key * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism * feat: enhance error message and retry mechanism : 5 * feat: enhance error message and retry mechanism : 6 * feat: enhance error message and retry mechanism : 7 * feat: enhance error message and retry mechanism : 8 * perf: catch chat error * perf: copy hook (#5246) * perf: copy hook * doc * doc * add app evaluation (#5083) * add app evaluation * fix * usage * variables * editing condition * var ui * isplus filter * migrate code * remove utils * name * update type * build * fix * fix * fix * delete comment * fix * perf: eval code * eval code * eval code * feat: ttfb time in model log * Refactor chat page (#5253) * feat: update side bar layout; add login and logout logic at chat page * refactor: encapsulate login logic and reuse it in `LoginModal` and `Login` page * chore: improve some logics and comments * chore: improve some logics * chore: remove redundant side effect; add translations --------- Co-authored-by: Archer <545436317@qq.com> * perf: chat page code * doc * perf: provider redirect * chore: ui improvement (#5266) * Fix: SSE * Fix: SSE * eval pagination (#5264) * eval scroll pagination * change eval list to manual pagination * number * fix build * fix * version doc (#5267) * version doc * version doc * doc * feat: eval model select * config eval model * perf: eval detail modal ui * doc * doc * fix: chat store reload * doc --------- Co-authored-by: colnii <1286949794@qq.com> Co-authored-by: heheer <heheer@sealos.io> Co-authored-by: 酒川户 <76519998+chuanhu9@users.noreply.github.com>
127 lines
4.0 KiB
TypeScript
127 lines
4.0 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);
|
|
}
|
|
}
|
|
};
|
|
|
|
export const checkTeamDatasetSyncPermission = async (teamId: string) => {
|
|
const { standardConstants } = await getTeamStandPlan({
|
|
teamId
|
|
});
|
|
|
|
if (standardConstants && !standardConstants?.permissionWebsiteSync) {
|
|
return Promise.reject(TeamErrEnum.websiteSyncNotEnough);
|
|
}
|
|
};
|