mirror of
https://github.com/labring/FastGPT.git
synced 2025-07-27 08:25:07 +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
76 lines
1.9 KiB
TypeScript
76 lines
1.9 KiB
TypeScript
import { type AppDetailType } from '@fastgpt/global/core/app/type';
|
|
import { type OutlinkAppType, type OutLinkSchema } from '@fastgpt/global/support/outLink/type';
|
|
import { parseHeaderCert } from '../controller';
|
|
import { MongoOutLink } from '../../outLink/schema';
|
|
import { OutLinkErrEnum } from '@fastgpt/global/common/error/code/outLink';
|
|
import { OwnerPermissionVal } from '@fastgpt/global/support/permission/constant';
|
|
import { authAppByTmbId } from '../app/auth';
|
|
import { type AuthModeType, type AuthResponseType } from '../type';
|
|
|
|
/* crud outlink permission */
|
|
export async function authOutLinkCrud({
|
|
outLinkId,
|
|
per = OwnerPermissionVal,
|
|
...props
|
|
}: AuthModeType & {
|
|
outLinkId: string;
|
|
}): Promise<
|
|
AuthResponseType & {
|
|
app: AppDetailType;
|
|
outLink: OutLinkSchema;
|
|
}
|
|
> {
|
|
const result = await parseHeaderCert(props);
|
|
const { tmbId, teamId } = result;
|
|
|
|
const { app, outLink } = await (async () => {
|
|
const outLink = await MongoOutLink.findOne({ _id: outLinkId, teamId });
|
|
if (!outLink) {
|
|
return Promise.reject(OutLinkErrEnum.unExist);
|
|
}
|
|
|
|
if (String(outLink.teamId) !== teamId) {
|
|
return Promise.reject(OutLinkErrEnum.unAuthLink);
|
|
}
|
|
|
|
const { app } = await authAppByTmbId({
|
|
tmbId,
|
|
appId: outLink.appId,
|
|
per
|
|
});
|
|
|
|
return {
|
|
outLink,
|
|
app
|
|
};
|
|
})();
|
|
|
|
return {
|
|
...result,
|
|
permission: app.permission,
|
|
app,
|
|
outLink
|
|
};
|
|
}
|
|
|
|
/* outLink exist and it app exist */
|
|
export async function authOutLinkValid<T extends OutlinkAppType = any>({
|
|
shareId
|
|
}: {
|
|
shareId?: string;
|
|
}) {
|
|
if (!shareId) {
|
|
return Promise.reject(OutLinkErrEnum.linkUnInvalid);
|
|
}
|
|
const outLinkConfig = await MongoOutLink.findOne({ shareId }).lean<OutLinkSchema<T>>();
|
|
|
|
if (!outLinkConfig) {
|
|
return Promise.reject(OutLinkErrEnum.linkUnInvalid);
|
|
}
|
|
|
|
return {
|
|
appId: outLinkConfig.appId,
|
|
outLinkConfig: outLinkConfig
|
|
};
|
|
}
|