X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Futils.ts;h=8f77c9fbd84060118df26ab1a6b8607b19d28f7a;hb=f0a3988066f72a28bb44520af072f18d91d77dde;hp=77a1a0d4bfb4c5a7ded8dec4ccdaecd890fc85a9;hpb=4e50b6a1c9a3eb261e04ede73241648e6edf21d6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/utils.ts b/server/middlewares/validators/utils.ts index 77a1a0d4b..8f77c9fbd 100644 --- a/server/middlewares/validators/utils.ts +++ b/server/middlewares/validators/utils.ts @@ -1,18 +1,6 @@ -import { validationResult } from 'express-validator/check' import * as express from 'express' - -import { logger } from '../../helpers' - -function checkErrors (req: express.Request, res: express.Response, next: express.NextFunction) { - const errors = validationResult(req) - - if (!errors.isEmpty()) { - logger.warn('Incorrect request parameters', { path: req.originalUrl, err: errors.mapped() }) - return res.status(400).json({ errors: errors.mapped() }) - } - - return next() -} +import { query, validationResult } from 'express-validator/check' +import { logger } from '../../helpers/logger' function areValidationErrors (req: express.Request, res: express.Response) { const errors = validationResult(req) @@ -27,9 +15,30 @@ function areValidationErrors (req: express.Request, res: express.Response) { return false } +function checkSort (sortableColumns: string[]) { + return [ + query('sort').optional().isIn(sortableColumns).withMessage('Should have correct sortable column'), + + (req: express.Request, res: express.Response, next: express.NextFunction) => { + logger.debug('Checking sort parameters', { parameters: req.query }) + + if (areValidationErrors(req, res)) return + + return next() + } + ] +} + +function createSortableColumns (sortableColumns: string[]) { + const sortableColumnDesc = sortableColumns.map(sortableColumn => '-' + sortableColumn) + + return sortableColumns.concat(sortableColumnDesc) +} + // --------------------------------------------------------------------------- export { - checkErrors, - areValidationErrors + areValidationErrors, + checkSort, + createSortableColumns }