mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-28 09:03:53 +00:00

* perf: redirect request and err log replace perf: dataset openapi feat: session fix: retry input error feat: 468 doc sub page feat: standard sub perf: rerank tip perf: rerank tip perf: api sdk perf: openapi sub plan perf: sub ui fix: ts * perf: init log * fix: variable select * sub page * icon * perf: llm model config * perf: menu ux * perf: system store * perf: publish app name * fix: init data * perf: flow edit ux * fix: value type format and ux * fix prompt editor default value (#13) * fix prompt editor default value * fix prompt editor update when not focus * add key with variable --------- Co-authored-by: Archer <545436317@qq.com> * fix: value type * doc * i18n * import path * home page * perf: mongo session running * fix: ts * perf: use toast * perf: flow edit * perf: sse response * slider ui * fetch error * fix prompt editor rerender when not focus by key defaultvalue (#14) * perf: prompt editor * feat: dataset search concat * perf: doc * fix:ts * perf: doc * fix json editor onblur value (#15) * faq * vector model default config * ipv6 --------- Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
88 lines
2.7 KiB
TypeScript
88 lines
2.7 KiB
TypeScript
import { SubTypeEnum } from '@fastgpt/global/support/wallet/sub/constants';
|
|
import { MongoTeamSub } from './schema';
|
|
import { addHours } from 'date-fns';
|
|
import { FeTeamSubType, StandSubPlanLevelMapType } from '@fastgpt/global/support/wallet/sub/type.d';
|
|
import { getVectorCountByTeamId } from '../../../common/vectorStore/controller';
|
|
|
|
/* get team dataset max size */
|
|
export const getTeamDatasetMaxSize = async ({
|
|
teamId,
|
|
standardPlans
|
|
}: {
|
|
teamId: string;
|
|
standardPlans?: StandSubPlanLevelMapType;
|
|
}) => {
|
|
if (!standardPlans) {
|
|
return {
|
|
maxSize: Infinity,
|
|
sub: null
|
|
};
|
|
}
|
|
|
|
const plans = await MongoTeamSub.find({
|
|
teamId,
|
|
expiredTime: { $gte: addHours(new Date(), -3) }
|
|
}).lean();
|
|
|
|
const standard = plans.find((plan) => plan.type === SubTypeEnum.standard);
|
|
const extraDatasetSize = plans.find((plan) => plan.type === SubTypeEnum.extraDatasetSize);
|
|
|
|
const standardMaxDatasetSize =
|
|
standard?.currentSubLevel && standardPlans
|
|
? standardPlans[standard.currentSubLevel]?.maxDatasetSize || Infinity
|
|
: Infinity;
|
|
const totalDatasetSize =
|
|
standardMaxDatasetSize + (extraDatasetSize?.currentExtraDatasetSize || 0);
|
|
|
|
return {
|
|
maxSize: totalDatasetSize,
|
|
sub: extraDatasetSize
|
|
};
|
|
};
|
|
|
|
export const getTeamSubPlanStatus = async ({
|
|
teamId,
|
|
standardPlans
|
|
}: {
|
|
teamId: string;
|
|
standardPlans?: StandSubPlanLevelMapType;
|
|
}): Promise<FeTeamSubType> => {
|
|
const [plans, usedDatasetSize] = await Promise.all([
|
|
MongoTeamSub.find({ teamId }).lean(),
|
|
getVectorCountByTeamId(teamId)
|
|
]);
|
|
|
|
const standard = plans.find((plan) => plan.type === SubTypeEnum.standard);
|
|
const extraDatasetSize = plans.find((plan) => plan.type === SubTypeEnum.extraDatasetSize);
|
|
const extraPoints = plans.find((plan) => plan.type === SubTypeEnum.extraPoints);
|
|
|
|
const standardMaxDatasetSize =
|
|
standard?.currentSubLevel && standardPlans
|
|
? standardPlans[standard.currentSubLevel]?.maxDatasetSize || Infinity
|
|
: Infinity;
|
|
const totalDatasetSize =
|
|
standardMaxDatasetSize + (extraDatasetSize?.currentExtraDatasetSize || 0);
|
|
|
|
const standardMaxPoints =
|
|
standard?.currentSubLevel && standardPlans
|
|
? standardPlans[standard.currentSubLevel]?.totalPoints || Infinity
|
|
: Infinity;
|
|
const totalPoints = standardMaxPoints + (extraPoints?.currentExtraPoints || 0);
|
|
|
|
const surplusPoints = (standard?.surplusPoints || 0) + (extraPoints?.surplusPoints || 0);
|
|
|
|
return {
|
|
[SubTypeEnum.standard]: standard,
|
|
[SubTypeEnum.extraDatasetSize]: extraDatasetSize,
|
|
[SubTypeEnum.extraPoints]: extraPoints,
|
|
|
|
standardMaxDatasetSize,
|
|
datasetMaxSize: totalDatasetSize,
|
|
usedDatasetSize,
|
|
|
|
standardMaxPoints,
|
|
totalPoints,
|
|
usedPoints: totalPoints - surplusPoints
|
|
};
|
|
};
|