X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmiddlewares%2Fvalidators%2Fsearch.ts;h=78213c70da16a02a163f63eb85489c541c5915bc;hb=428ccb8b7a44ce60cabb7401a5464cf5fcbd4dba;hp=774845e8a38e93a55d69acf7592050d57cb2e2ff;hpb=57c36b277e68b764dd34cb2e449f6e2ca3d1e9b6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/middlewares/validators/search.ts b/server/middlewares/validators/search.ts index 774845e8a..78213c70d 100644 --- a/server/middlewares/validators/search.ts +++ b/server/middlewares/validators/search.ts @@ -1,13 +1,51 @@ import * as express from 'express' import { areValidationErrors } from './utils' import { logger } from '../../helpers/logger' -import { query } from 'express-validator/check' +import { query } from 'express-validator' +import { isDateValid } from '../../helpers/custom-validators/misc' +import { isSearchTargetValid } from '@server/helpers/custom-validators/search' -const searchValidator = [ +const videosSearchValidator = [ + query('search').optional().not().isEmpty().withMessage('Should have a valid search'), + + query('startDate').optional().custom(isDateValid).withMessage('Should have a valid start date'), + query('endDate').optional().custom(isDateValid).withMessage('Should have a valid end date'), + + query('originallyPublishedStartDate').optional().custom(isDateValid).withMessage('Should have a valid published start date'), + query('originallyPublishedEndDate').optional().custom(isDateValid).withMessage('Should have a valid published end date'), + + query('durationMin').optional().isInt().withMessage('Should have a valid min duration'), + query('durationMax').optional().isInt().withMessage('Should have a valid max duration'), + + query('searchTarget').optional().custom(isSearchTargetValid).withMessage('Should have a valid search target'), + + (req: express.Request, res: express.Response, next: express.NextFunction) => { + logger.debug('Checking videos search query', { parameters: req.query }) + + if (areValidationErrors(req, res)) return + + return next() + } +] + +const videoChannelsListSearchValidator = [ query('search').not().isEmpty().withMessage('Should have a valid search'), + query('searchTarget').optional().custom(isSearchTargetValid).withMessage('Should have a valid search target'), + + (req: express.Request, res: express.Response, next: express.NextFunction) => { + logger.debug('Checking video channels search query', { parameters: req.query }) + + if (areValidationErrors(req, res)) return + + return next() + } +] + +const videoChannelsOwnSearchValidator = [ + query('search').optional().not().isEmpty().withMessage('Should have a valid search'), (req: express.Request, res: express.Response, next: express.NextFunction) => { - logger.debug('Checking search parameters', { parameters: req.params }) + logger.debug('Checking video channels search query', { parameters: req.query }) if (areValidationErrors(req, res)) return @@ -18,5 +56,7 @@ const searchValidator = [ // --------------------------------------------------------------------------- export { - searchValidator + videosSearchValidator, + videoChannelsListSearchValidator, + videoChannelsOwnSearchValidator }