]>
Commit | Line | Data |
---|---|---|
cef534ed C |
1 | import * as express from 'express' |
2 | import 'express-validator' | |
dc133480 | 3 | import { body, query } from 'express-validator/check' |
cef534ed C |
4 | import { logger } from '../../helpers/logger' |
5 | import { areValidationErrors } from './utils' | |
6 | import { isUserNotificationSettingValid } from '../../helpers/custom-validators/user-notifications' | |
2f1548fd | 7 | import { isNotEmptyIntArray } from '../../helpers/custom-validators/misc' |
cef534ed | 8 | |
dc133480 C |
9 | const listUserNotificationsValidator = [ |
10 | query('unread') | |
11 | .optional() | |
12 | .toBoolean() | |
13 | .isBoolean().withMessage('Should have a valid unread boolean'), | |
14 | ||
15 | (req: express.Request, res: express.Response, next: express.NextFunction) => { | |
16 | logger.debug('Checking listUserNotificationsValidator parameters', { parameters: req.query }) | |
17 | ||
18 | if (areValidationErrors(req, res)) return | |
19 | ||
20 | return next() | |
21 | } | |
22 | ] | |
23 | ||
cef534ed C |
24 | const updateNotificationSettingsValidator = [ |
25 | body('newVideoFromSubscription') | |
26 | .custom(isUserNotificationSettingValid).withMessage('Should have a valid new video from subscription notification setting'), | |
27 | body('newCommentOnMyVideo') | |
28 | .custom(isUserNotificationSettingValid).withMessage('Should have a valid new comment on my video notification setting'), | |
29 | body('videoAbuseAsModerator') | |
30 | .custom(isUserNotificationSettingValid).withMessage('Should have a valid new video abuse as moderator notification setting'), | |
31 | body('blacklistOnMyVideo') | |
32 | .custom(isUserNotificationSettingValid).withMessage('Should have a valid new blacklist on my video notification setting'), | |
33 | ||
34 | (req: express.Request, res: express.Response, next: express.NextFunction) => { | |
35 | logger.debug('Checking updateNotificationSettingsValidator parameters', { parameters: req.body }) | |
36 | ||
37 | if (areValidationErrors(req, res)) return | |
38 | ||
39 | return next() | |
40 | } | |
41 | ] | |
42 | ||
43 | const markAsReadUserNotificationsValidator = [ | |
44 | body('ids') | |
2f1548fd C |
45 | .optional() |
46 | .custom(isNotEmptyIntArray).withMessage('Should have a valid notification ids to mark as read'), | |
cef534ed C |
47 | |
48 | (req: express.Request, res: express.Response, next: express.NextFunction) => { | |
49 | logger.debug('Checking markAsReadUserNotificationsValidator parameters', { parameters: req.body }) | |
50 | ||
51 | if (areValidationErrors(req, res)) return | |
52 | ||
53 | return next() | |
54 | } | |
55 | ] | |
56 | ||
57 | // --------------------------------------------------------------------------- | |
58 | ||
59 | export { | |
dc133480 | 60 | listUserNotificationsValidator, |
cef534ed C |
61 | updateNotificationSettingsValidator, |
62 | markAsReadUserNotificationsValidator | |
63 | } |