mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-23 05:12:39 +00:00

* update: Add type * fix: update import statement for NextApiRequest type * fix: update imports to use type for LexicalEditor and EditorState * Refactor imports to use 'import type' for type-only imports across multiple files - Updated imports in various components and API files to use 'import type' for better clarity and to optimize TypeScript's type checking. - Ensured consistent usage of type imports in files related to chat, dataset, workflow, and user management. - Improved code readability and maintainability by distinguishing between value and type imports. * refactor: remove old ESLint configuration and add new rules - Deleted the old ESLint configuration file from the app project. - Added a new ESLint configuration file with updated rules and settings. - Changed imports to use type-only imports in various files for better clarity and performance. - Updated TypeScript configuration to remove unnecessary options. - Added an ESLint ignore file to exclude build and dependency directories from linting. * fix: update imports to use 'import type' for type-only imports in schema files
154 lines
3.9 KiB
TypeScript
154 lines
3.9 KiB
TypeScript
import { TeamErrEnum } from '@fastgpt/global/common/error/code/team';
|
|
import type { AuthUserTypeEnum } from '@fastgpt/global/support/permission/constant';
|
|
import { TeamPermission } from '@fastgpt/global/support/permission/user/controller';
|
|
import { MongoGroupMemberModel } from '@fastgpt/service/support/permission/memberGroup/groupMemberSchema';
|
|
import { getTmbInfoByTmbId } from '@fastgpt/service/support/user/team/controller';
|
|
import { vi } from 'vitest';
|
|
|
|
// vi.mock(import('@/service/middleware/entry'), async () => {
|
|
// const NextAPI = vi.fn((handler: any) => handler);
|
|
// return {
|
|
// NextAPI
|
|
// };
|
|
// });
|
|
|
|
vi.mock(import('@fastgpt/service/common/middle/entry'), async (importOriginal) => {
|
|
const mod = await importOriginal();
|
|
const NextEntry = vi.fn(({ beforeCallback = [] }: { beforeCallback?: Promise<any>[] }) => {
|
|
return (...args: any) => {
|
|
return async function api(req: any, res: any) {
|
|
try {
|
|
await Promise.all([...beforeCallback]);
|
|
let response = null;
|
|
for await (const handler of args) {
|
|
response = await handler(req, res);
|
|
if (res.writableFinished) {
|
|
break;
|
|
}
|
|
}
|
|
return {
|
|
code: 200,
|
|
data: response
|
|
};
|
|
} catch (error) {
|
|
return {
|
|
code: 500,
|
|
error,
|
|
url: req.url
|
|
};
|
|
}
|
|
};
|
|
};
|
|
});
|
|
|
|
return {
|
|
...mod,
|
|
NextEntry
|
|
};
|
|
});
|
|
|
|
export type parseHeaderCertRet = {
|
|
userId: string;
|
|
teamId: string;
|
|
tmbId: string;
|
|
appId: string;
|
|
authType: AuthUserTypeEnum;
|
|
sourceName: string | undefined;
|
|
apikey: string;
|
|
isRoot: boolean;
|
|
};
|
|
|
|
export type MockReqType<B = any, Q = any> = {
|
|
body?: B;
|
|
query?: Q;
|
|
headers?: Record<string, any>;
|
|
auth?: parseHeaderCertRet;
|
|
[key: string]: any;
|
|
};
|
|
|
|
vi.mock(import('@fastgpt/service/support/permission/controller'), async (importOriginal) => {
|
|
const mod = await importOriginal();
|
|
const parseHeaderCert = vi.fn(
|
|
({
|
|
req,
|
|
authToken = false,
|
|
authRoot = false,
|
|
authApiKey = false
|
|
}: {
|
|
req: MockReqType;
|
|
authToken?: boolean;
|
|
authRoot?: boolean;
|
|
authApiKey?: boolean;
|
|
}) => {
|
|
const { auth } = req;
|
|
if (!auth) {
|
|
return Promise.reject(Error('unAuthorization'));
|
|
}
|
|
return Promise.resolve(auth);
|
|
}
|
|
);
|
|
return {
|
|
...mod,
|
|
parseHeaderCert
|
|
};
|
|
});
|
|
|
|
vi.mock(
|
|
import('@fastgpt/service/support/permission/memberGroup/controllers'),
|
|
async (importOriginal) => {
|
|
const mod = await importOriginal();
|
|
const parseHeaderCert = vi.fn(
|
|
({
|
|
req,
|
|
authToken = false,
|
|
authRoot = false,
|
|
authApiKey = false
|
|
}: {
|
|
req: MockReqType;
|
|
authToken?: boolean;
|
|
authRoot?: boolean;
|
|
authApiKey?: boolean;
|
|
}) => {
|
|
const { auth } = req;
|
|
if (!auth) {
|
|
return Promise.reject(Error('unAuthorization(mock)'));
|
|
}
|
|
return Promise.resolve(auth);
|
|
}
|
|
);
|
|
const authGroupMemberRole = vi.fn(async ({ groupId, role, ...props }: any) => {
|
|
const result = await parseHeaderCert(props);
|
|
const { teamId, tmbId, isRoot } = result;
|
|
if (isRoot) {
|
|
return {
|
|
...result,
|
|
permission: new TeamPermission({
|
|
isOwner: true
|
|
}),
|
|
teamId,
|
|
tmbId
|
|
};
|
|
}
|
|
const [groupMember, tmb] = await Promise.all([
|
|
MongoGroupMemberModel.findOne({ groupId, tmbId }),
|
|
getTmbInfoByTmbId({ tmbId })
|
|
]);
|
|
|
|
// Team admin or role check
|
|
if (tmb.permission.hasManagePer || (groupMember && role.includes(groupMember.role))) {
|
|
return {
|
|
...result,
|
|
permission: tmb.permission,
|
|
teamId,
|
|
tmbId
|
|
};
|
|
}
|
|
return Promise.reject(TeamErrEnum.unAuthTeam);
|
|
});
|
|
return {
|
|
...mod,
|
|
authGroupMemberRole
|
|
};
|
|
}
|
|
);
|