mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 13:03:50 +00:00
182 lines
5.0 KiB
TypeScript
182 lines
5.0 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 { getTeamInfoByTmbId } from '../../user/team/controller';
|
|
|
|
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 { role } = await getTeamInfoByTmbId({ tmbId });
|
|
|
|
const { dataset, isOwner, canWrite } = await (async () => {
|
|
const dataset = (await MongoDataset.findOne({ _id: datasetId, teamId }))?.toObject();
|
|
|
|
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 {
|
|
...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 { userId, teamId, tmbId } = await parseHeaderCert(props);
|
|
const { role } = await getTeamInfoByTmbId({ 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.datasetId.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 {
|
|
userId,
|
|
teamId,
|
|
tmbId,
|
|
collection,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
}
|
|
|
|
export async function authDatasetFile({
|
|
fileId,
|
|
per = 'owner',
|
|
...props
|
|
}: AuthModeType & {
|
|
fileId: string;
|
|
}): Promise<
|
|
AuthResponseType & {
|
|
file: DatasetFileSchema;
|
|
}
|
|
> {
|
|
const { userId, teamId, tmbId } = await parseHeaderCert(props);
|
|
const { role } = await getTeamInfoByTmbId({ tmbId });
|
|
|
|
const file = await getFileById({ bucketName: BucketNameEnum.dataset, fileId });
|
|
|
|
if (file.metadata.teamId !== teamId) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
|
|
const { dataset } = await authDataset({
|
|
...props,
|
|
datasetId: file.metadata.datasetId,
|
|
per
|
|
});
|
|
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' && !isOwner && dataset.permission !== PermissionTypeEnum.public) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
if (per === 'w' && !canWrite) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
if (per === 'owner' && !isOwner) {
|
|
return Promise.reject(DatasetErrEnum.unAuthDatasetFile);
|
|
}
|
|
|
|
return {
|
|
userId,
|
|
teamId,
|
|
tmbId,
|
|
file,
|
|
isOwner,
|
|
canWrite
|
|
};
|
|
}
|