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
54 lines
1.6 KiB
TypeScript
54 lines
1.6 KiB
TypeScript
import { jsonRes } from '../response';
|
|
import type { NextApiResponse } from 'next';
|
|
import { withNextCors } from './cors';
|
|
import { type ApiRequestProps } from '../../type/next';
|
|
import { addLog } from '../system/log';
|
|
|
|
export type NextApiHandler<T = any> = (
|
|
req: ApiRequestProps,
|
|
res: NextApiResponse<T>
|
|
) => unknown | Promise<unknown>;
|
|
|
|
export const NextEntry = ({ beforeCallback = [] }: { beforeCallback?: Promise<any>[] }) => {
|
|
return (...args: NextApiHandler[]): NextApiHandler => {
|
|
return async function api(req: ApiRequestProps, res: NextApiResponse) {
|
|
const start = Date.now();
|
|
addLog.debug(`Request start ${req.url}`);
|
|
|
|
try {
|
|
await Promise.all([withNextCors(req, res), ...beforeCallback]);
|
|
|
|
let response = null;
|
|
for await (const handler of args) {
|
|
response = await handler(req, res);
|
|
if (res.writableFinished) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
// Get request duration
|
|
const duration = Date.now() - start;
|
|
if (duration < 2000) {
|
|
addLog.debug(`Request finish ${req.url}, time: ${duration}ms`);
|
|
} else {
|
|
addLog.warn(`Request finish ${req.url}, time: ${duration}ms`);
|
|
}
|
|
|
|
const contentType = res.getHeader('Content-Type');
|
|
if ((!contentType || contentType === 'application/json') && !res.writableFinished) {
|
|
return jsonRes(res, {
|
|
code: 200,
|
|
data: response
|
|
});
|
|
}
|
|
} catch (error) {
|
|
return jsonRes(res, {
|
|
code: 500,
|
|
error,
|
|
url: req.url
|
|
});
|
|
}
|
|
};
|
|
};
|
|
};
|