From 6b9a242be57f94433397da1301928b80479f858e Mon Sep 17 00:00:00 2001 From: Mateusz Kwasniewski Date: Thu, 26 Jan 2023 12:36:45 +0100 Subject: [PATCH] upload limit and import ui tweaks (#2998) --- .../Project/Import/validate/ValidationStage.tsx | 14 +++++++++----- src/lib/app.ts | 13 ++++++++++++- src/lib/middleware/unless-middleware.ts | 11 +++++++++++ src/lib/services/export-import-service.ts | 6 ------ 4 files changed, 32 insertions(+), 12 deletions(-) create mode 100644 src/lib/middleware/unless-middleware.ts diff --git a/frontend/src/component/project/Project/Import/validate/ValidationStage.tsx b/frontend/src/component/project/Project/Import/validate/ValidationStage.tsx index ad0ab59eb5..3246e04bff 100644 --- a/frontend/src/component/project/Project/Import/validate/ValidationStage.tsx +++ b/frontend/src/component/project/Project/Import/validate/ValidationStage.tsx @@ -159,12 +159,16 @@ export const ValidationStage: FC<{ the import, they will be overwritten with the configuration from this import file - {validationResult.warnings.map(error => ( - - {error.message} + {validationResult.warnings.map(warning => ( + + + {warning.message} + - {error.affectedItems.map(item => ( - {item} + {warning.affectedItems.map(item => ( + + {item} + ))} diff --git a/src/lib/app.ts b/src/lib/app.ts index 44f24bca3a..2be2c17110 100644 --- a/src/lib/app.ts +++ b/src/lib/app.ts @@ -26,6 +26,7 @@ import { conditionalMiddleware } from './middleware/conditional-middleware'; import patMiddleware from './middleware/pat-middleware'; import { Knex } from 'knex'; import maintenanceMiddleware from './middleware/maintenance-middleware'; +import { unless } from './middleware/unless-middleware'; export default async function getApp( config: IUnleashConfig, @@ -62,7 +63,17 @@ export default async function getApp( app.use(compression()); app.use(cookieParser()); - app.use(express.json({ strict: false })); + + app.use( + `${baseUriPath}/api/admin/features-batch`, + express.json({ strict: false, limit: '500kB' }), + ); + app.use( + unless( + `${baseUriPath}/api/admin/features-batch`, + express.json({ strict: false }), + ), + ); if (unleashSession) { app.use(unleashSession); } diff --git a/src/lib/middleware/unless-middleware.ts b/src/lib/middleware/unless-middleware.ts new file mode 100644 index 0000000000..709e0f7a00 --- /dev/null +++ b/src/lib/middleware/unless-middleware.ts @@ -0,0 +1,11 @@ +import { RequestHandler } from 'express'; + +export const unless = + (path: string, middleware: RequestHandler): RequestHandler => + (req, res, next) => { + if (path === req.path) { + return next(); + } else { + return middleware(req, res, next); + } + }; diff --git a/src/lib/services/export-import-service.ts b/src/lib/services/export-import-service.ts index 8fdbfca015..6ede6a1d82 100644 --- a/src/lib/services/export-import-service.ts +++ b/src/lib/services/export-import-service.ts @@ -18,12 +18,6 @@ import { ExportQuerySchema } from '../openapi/spec/export-query-schema'; import { FEATURES_EXPORTED, IFlagResolver, IUnleashServices } from '../types'; import { ExportResultSchema } from '../openapi'; -export interface IImportDTO { - data: ExportResultSchema; - project: string; - environment: string; -} - export default class ExportImportService { private logger: Logger;