1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- import * as express from 'express'
- import { body, param, query } from 'express-validator'
- import { isBooleanValid, isIdOrUUIDValid, toBooleanOrNull, toIntOrNull } from '../../../helpers/custom-validators/misc'
- import { isVideoBlacklistReasonValid, isVideoBlacklistTypeValid } from '../../../helpers/custom-validators/video-blacklist'
- import { logger } from '../../../helpers/logger'
- import { doesVideoBlacklistExist, doesVideoExist } from '../../../helpers/middlewares'
- import { areValidationErrors } from '../utils'
- import { HttpStatusCode } from '../../../../shared/core-utils/miscs/http-error-codes'
- const videosBlacklistRemoveValidator = [
- param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
- async (req: express.Request, res: express.Response, next: express.NextFunction) => {
- logger.debug('Checking blacklistRemove parameters.', { parameters: req.params })
- if (areValidationErrors(req, res)) return
- if (!await doesVideoExist(req.params.videoId, res)) return
- if (!await doesVideoBlacklistExist(res.locals.videoAll.id, res)) return
- return next()
- }
- ]
- const videosBlacklistAddValidator = [
- param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
- body('unfederate')
- .optional()
- .customSanitizer(toBooleanOrNull)
- .custom(isBooleanValid).withMessage('Should have a valid unfederate boolean'),
- body('reason')
- .optional()
- .custom(isVideoBlacklistReasonValid).withMessage('Should have a valid reason'),
- async (req: express.Request, res: express.Response, next: express.NextFunction) => {
- logger.debug('Checking videosBlacklistAdd parameters', { parameters: req.params })
- if (areValidationErrors(req, res)) return
- if (!await doesVideoExist(req.params.videoId, res)) return
- const video = res.locals.videoAll
- if (req.body.unfederate === true && video.remote === true) {
- return res
- .status(HttpStatusCode.CONFLICT_409)
- .send({ error: 'You cannot unfederate a remote video.' })
- .end()
- }
- return next()
- }
- ]
- const videosBlacklistUpdateValidator = [
- param('videoId').custom(isIdOrUUIDValid).not().isEmpty().withMessage('Should have a valid videoId'),
- body('reason')
- .optional()
- .custom(isVideoBlacklistReasonValid).withMessage('Should have a valid reason'),
- async (req: express.Request, res: express.Response, next: express.NextFunction) => {
- logger.debug('Checking videosBlacklistUpdate parameters', { parameters: req.params })
- if (areValidationErrors(req, res)) return
- if (!await doesVideoExist(req.params.videoId, res)) return
- if (!await doesVideoBlacklistExist(res.locals.videoAll.id, res)) return
- return next()
- }
- ]
- const videosBlacklistFiltersValidator = [
- query('type')
- .optional()
- .customSanitizer(toIntOrNull)
- .custom(isVideoBlacklistTypeValid).withMessage('Should have a valid video blacklist type attribute'),
- query('search')
- .optional()
- .not()
- .isEmpty().withMessage('Should have a valid search'),
- (req: express.Request, res: express.Response, next: express.NextFunction) => {
- logger.debug('Checking videos blacklist filters query', { parameters: req.query })
- if (areValidationErrors(req, res)) return
- return next()
- }
- ]
- // ---------------------------------------------------------------------------
- export {
- videosBlacklistAddValidator,
- videosBlacklistRemoveValidator,
- videosBlacklistUpdateValidator,
- videosBlacklistFiltersValidator
- }
|