]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - server/middlewares/validators/actor-image.ts
Merge branch 'release/3.2.0' into develop
[github/Chocobozzz/PeerTube.git] / server / middlewares / validators / actor-image.ts
CommitLineData
4bbfc6c6 1import * as express from 'express'
c8861d5d 2import { body } from 'express-validator'
213e30ef 3import { isActorImageFile } from '@server/helpers/custom-validators/actor-images'
06215f15 4import { cleanUpReqFiles } from '../../helpers/express-utils'
213e30ef
C
5import { logger } from '../../helpers/logger'
6import { CONSTRAINTS_FIELDS } from '../../initializers/constants'
7import { areValidationErrors } from './utils'
4bbfc6c6 8
2cb03dc1 9const updateActorImageValidatorFactory = (fieldname: string) => ([
213e30ef 10 body(fieldname).custom((value, { req }) => isActorImageFile(req.files, fieldname)).withMessage(
a1587156 11 'This file is not supported or too large. Please, make sure it is of the following type : ' +
2cb03dc1 12 CONSTRAINTS_FIELDS.ACTORS.IMAGE.EXTNAME.join(', ')
4bbfc6c6
C
13 ),
14
15 (req: express.Request, res: express.Response, next: express.NextFunction) => {
2cb03dc1 16 logger.debug('Checking updateActorImageValidator parameters', { files: req.files })
4bbfc6c6 17
cf7a61b5 18 if (areValidationErrors(req, res)) return cleanUpReqFiles(req)
4bbfc6c6
C
19
20 return next()
21 }
2cb03dc1
C
22])
23
24const updateAvatarValidator = updateActorImageValidatorFactory('avatarfile')
25const updateBannerValidator = updateActorImageValidatorFactory('bannerfile')
4bbfc6c6
C
26
27export {
2cb03dc1
C
28 updateAvatarValidator,
29 updateBannerValidator
4bbfc6c6 30}