mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-22 20:37:48 +00:00

* perf: insert mongo dataset data session * perf: dataset data index * remove delay * rename bill schema * rename bill record * perf: bill table * perf: prompt * perf: sub plan * change the usage count * feat: usage bill * publish usages * doc * 新增团队聊天功能 (#20) * perf: doc * feat 添加标签部分 feat 信息团队标签配置 feat 新增团队同步管理 feat team分享页面 feat 完成team分享页面 feat 实现模糊搜索 style 格式化 fix 修复迷糊匹配 style 样式修改 fix 团队标签功能修复 * fix 修复鉴权功能 * merge 合并代码 * fix 修复引用错误 * fix 修复pr问题 * fix 修复ts格式问题 --------- Co-authored-by: archer <545436317@qq.com> Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> * update extra plan * fix: ts * format * perf: bill field * feat: standard plan * fix: ts * feat 个人账号页面修改 (#22) * feat 添加标签部分 feat 信息团队标签配置 feat 新增团队同步管理 feat team分享页面 feat 完成team分享页面 feat 实现模糊搜索 style 格式化 fix 修复迷糊匹配 style 样式修改 fix 团队标签功能修复 * fix 修复鉴权功能 * merge 合并代码 * fix 修复引用错误 * fix 修复pr问题 * fix 修复ts格式问题 * feat 修改个人账号页 --------- Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> * sub plan page (#23) * fix chunk index; error page text * feat: dataset process Integral prediction * feat: stand plan field * feat: sub plan limit * perf: index * query extension * perf: share link push app name * perf: plan point unit * perf: get sub plan * perf: account page * feat 新增套餐详情弹窗代码 (#24) * merge 合并代码 * fix 新增套餐详情弹框 * fix 修复pr问题 * feat: change http node input to prompt editor (#21) * feat: change http node input to prompt editor * fix * split PromptEditor to HttpInput * Team plans (#25) * perf: pay check * perf: team plan test * plan limit check * replace sensitive text * perf: fix some null * collection null check * perf: plans modal * perf: http module * pacakge (#26) * individuation page and pay modal amount (#27) * feat: individuation page * team chat config * pay modal * plan count and replace invalid chars (#29) * fix: user oneapi * fix: training queue * fix: qa queue * perf: remove space chars * replace invalid chars * change httpinput dropdown menu (#28) * perf: http * reseet free plan * perf: plan code to packages * remove llm config to package * perf: code * perf: faq * fix: get team plan --------- Co-authored-by: yst <77910600+yu-and-liu@users.noreply.github.com> Co-authored-by: liuxingwan <liuxingwan.lxw@alibaba-inc.com> Co-authored-by: heheer <71265218+newfish-cmyk@users.noreply.github.com>
201 lines
5.1 KiB
TypeScript
201 lines
5.1 KiB
TypeScript
import { AuthModeType } from '../type';
|
|
import { parseHeaderCert } from '../controller';
|
|
import { DatasetErrEnum } from '@fastgpt/global/common/error/code/dataset';
|
|
import { MongoDataset } from '../../../core/dataset/schema';
|
|
import { getCollectionWithDataset } from '../../../core/dataset/controller';
|
|
import { PermissionTypeEnum } from '@fastgpt/global/support/permission/constant';
|
|
import { TeamMemberRoleEnum } from '@fastgpt/global/support/user/team/constant';
|
|
import { AuthResponseType } from '@fastgpt/global/support/permission/type';
|
|
import {
|
|
CollectionWithDatasetType,
|
|
DatasetFileSchema,
|
|
DatasetSchemaType
|
|
} from '@fastgpt/global/core/dataset/type';
|
|
import { getFileById } from '../../../common/file/gridfs/controller';
|
|
import { BucketNameEnum } from '@fastgpt/global/common/file/constants';
|
|
import { getTmbInfoByTmbId } from '../../user/team/controller';
|
|
import { CommonErrEnum } from '@fastgpt/global/common/error/code/common';
|
|
import { MongoDatasetCollection } from '../../../core/dataset/collection/schema';
|
|
|
|
export async function authDatasetByTmbId({
|
|
teamId,
|
|
tmbId,
|
|
datasetId,
|
|
per
|
|
}: {
|
|
teamId: string;
|
|
tmbId: string;
|
|
datasetId: string;
|
|
per: AuthModeType['per'];
|
|
}) {
|
|
const { role } = await getTmbInfoByTmbId({ tmbId });
|
|
|
|
const { dataset, isOwner, canWrite } = await (async () => {
|
|
const dataset = await MongoDataset.findOne({ _id: datasetId, teamId }).lean();
|
|
|
|
if (!dataset) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDataset);
|
|
}
|
|
|
|
const isOwner =
|
|
role !== TeamMemberRoleEnum.visitor &&
|
|
(String(dataset.tmbId) === tmbId || role === TeamMemberRoleEnum.owner);
|
|
const canWrite =
|
|
isOwner ||
|
|
(role !== TeamMemberRoleEnum.visitor && dataset.permission === PermissionTypeEnum.public);
|
|
if (per === 'r') {
|
|
if (!isOwner && dataset.permission !== PermissionTypeEnum.public) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDataset);
|
|
}
|
|
}
|
|
if (per === 'w' && !canWrite) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDataset);
|
|
}
|
|
if (per === 'owner' && !isOwner) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDataset);
|
|
}
|
|
|
|
return { dataset, isOwner, canWrite };
|
|
})();
|
|
|
|
return {
|
|
dataset,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
}
|
|
export async function authDataset({
|
|
datasetId,
|
|
per = 'owner',
|
|
...props
|
|
}: AuthModeType & {
|
|
datasetId: string;
|
|
}): Promise<
|
|
AuthResponseType & {
|
|
dataset: DatasetSchemaType;
|
|
}
|
|
> {
|
|
const result = await parseHeaderCert(props);
|
|
const { teamId, tmbId } = result;
|
|
const { dataset, isOwner, canWrite } = await authDatasetByTmbId({
|
|
teamId,
|
|
tmbId,
|
|
datasetId,
|
|
per
|
|
});
|
|
|
|
return {
|
|
...result,
|
|
dataset,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
}
|
|
|
|
/*
|
|
Read: in team and dataset permission is public
|
|
Write: in team, not visitor and dataset permission is public
|
|
*/
|
|
export async function authDatasetCollection({
|
|
collectionId,
|
|
per = 'owner',
|
|
...props
|
|
}: AuthModeType & {
|
|
collectionId: string;
|
|
}): Promise<
|
|
AuthResponseType & {
|
|
collection: CollectionWithDatasetType;
|
|
}
|
|
> {
|
|
const { teamId, tmbId } = await parseHeaderCert(props);
|
|
const { role } = await getTmbInfoByTmbId({ tmbId });
|
|
|
|
const { collection, isOwner, canWrite } = await (async () => {
|
|
const collection = await getCollectionWithDataset(collectionId);
|
|
|
|
if (!collection || String(collection.teamId) !== teamId) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetCollection);
|
|
}
|
|
|
|
const isOwner = String(collection.tmbId) === tmbId || role === TeamMemberRoleEnum.owner;
|
|
const canWrite =
|
|
isOwner ||
|
|
(role !== TeamMemberRoleEnum.visitor &&
|
|
collection.datasetId.permission === PermissionTypeEnum.public);
|
|
|
|
if (per === 'r') {
|
|
if (!isOwner && collection.datasetId.permission !== PermissionTypeEnum.public) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetCollection);
|
|
}
|
|
}
|
|
if (per === 'w' && !canWrite) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetCollection);
|
|
}
|
|
if (per === 'owner' && !isOwner) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetCollection);
|
|
}
|
|
|
|
return {
|
|
collection,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
})();
|
|
|
|
return {
|
|
teamId,
|
|
tmbId,
|
|
collection,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
}
|
|
|
|
export async function authDatasetFile({
|
|
fileId,
|
|
per = 'owner',
|
|
...props
|
|
}: AuthModeType & {
|
|
fileId: string;
|
|
}): Promise<
|
|
AuthResponseType & {
|
|
file: DatasetFileSchema;
|
|
}
|
|
> {
|
|
const { teamId, tmbId } = await parseHeaderCert(props);
|
|
|
|
const [file, collection] = await Promise.all([
|
|
getFileById({ bucketName: BucketNameEnum.dataset, fileId }),
|
|
MongoDatasetCollection.findOne({
|
|
teamId,
|
|
fileId
|
|
})
|
|
]);
|
|
|
|
if (!file) {
|
|
return Promise.reject(CommonErrEnum.fileNotFound);
|
|
}
|
|
|
|
if (!collection) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
|
|
// file role = collection role
|
|
try {
|
|
const { isOwner, canWrite } = await authDatasetCollection({
|
|
...props,
|
|
collectionId: collection._id,
|
|
per
|
|
});
|
|
|
|
return {
|
|
teamId,
|
|
tmbId,
|
|
file,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
} catch (error) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
} |