X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Futils.ts;h=4167f6d437f7ca9273abe998d2165ac74966e168;hb=f479685678406a5df864d89615b33d29085ebfc6;hp=61f76b457a4e5df65f67369ddad3329eb4d986af;hpb=3fd3ab2d34d512b160a5e6084d7609be7b4f4452;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/utils.ts b/server/middlewares/validators/utils.ts index 61f76b457..4167f6d43 100644 --- a/server/middlewares/validators/utils.ts +++ b/server/middlewares/validators/utils.ts @@ -1,13 +1,15 @@ import * as express from 'express' -import { validationResult } from 'express-validator/check' -import { logger } from '../../helpers' +import { query, validationResult } from 'express-validator' +import { logger } from '../../helpers/logger' +import { HttpStatusCode } from '../../../shared/core-utils/miscs/http-error-codes' function areValidationErrors (req: express.Request, res: express.Response) { const errors = validationResult(req) if (!errors.isEmpty()) { logger.warn('Incorrect request parameters', { path: req.originalUrl, err: errors.mapped() }) - res.status(400).json({ errors: errors.mapped() }) + res.status(HttpStatusCode.BAD_REQUEST_400) + .json({ errors: errors.mapped() }) return true } @@ -15,8 +17,30 @@ function areValidationErrors (req: express.Request, res: express.Response) { return false } +function checkSort (sortableColumns: string[], tags: 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, tags }) + + if (areValidationErrors(req, res)) return + + return next() + } + ] +} + +function createSortableColumns (sortableColumns: string[]) { + const sortableColumnDesc = sortableColumns.map(sortableColumn => '-' + sortableColumn) + + return sortableColumns.concat(sortableColumnDesc) +} + // --------------------------------------------------------------------------- export { - areValidationErrors + areValidationErrors, + checkSort, + createSortableColumns }