]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blob - server/helpers/custom-validators/users.ts
Fix trending days display on first load
[github/Chocobozzz/PeerTube.git] / server / helpers / custom-validators / users.ts
1 import 'express-validator'
2 import * as validator from 'validator'
3 import { UserRole } from '../../../shared'
4 import { CONSTRAINTS_FIELDS, NSFW_POLICY_TYPES } from '../../initializers'
5 import { exists, isFileValid, isBooleanValid } from './misc'
6 import { values } from 'lodash'
7
8 const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
9
10 function isUserPasswordValid (value: string) {
11 return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
12 }
13
14 function isUserVideoQuotaValid (value: string) {
15 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA)
16 }
17
18 function isUserVideoQuotaDailyValid (value: string) {
19 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA_DAILY)
20 }
21
22 function isUserUsernameValid (value: string) {
23 const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
24 const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
25 return exists(value) && validator.matches(value, new RegExp(`^[a-z0-9._]{${min},${max}}$`))
26 }
27
28 function isUserDisplayNameValid (value: string) {
29 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.NAME))
30 }
31
32 function isUserDescriptionValid (value: string) {
33 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.DESCRIPTION))
34 }
35
36 function isUserEmailVerifiedValid (value: any) {
37 return isBooleanValid(value)
38 }
39
40 const nsfwPolicies = values(NSFW_POLICY_TYPES)
41 function isUserNSFWPolicyValid (value: any) {
42 return exists(value) && nsfwPolicies.indexOf(value) !== -1
43 }
44
45 function isUserWebTorrentEnabledValid (value: any) {
46 return isBooleanValid(value)
47 }
48
49 function isUserVideosHistoryEnabledValid (value: any) {
50 return isBooleanValid(value)
51 }
52
53 function isUserAutoPlayVideoValid (value: any) {
54 return isBooleanValid(value)
55 }
56
57 function isUserBlockedValid (value: any) {
58 return isBooleanValid(value)
59 }
60
61 function isUserBlockedReasonValid (value: any) {
62 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
63 }
64
65 function isUserRoleValid (value: any) {
66 return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
67 }
68
69 const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
70 .map(v => v.replace('.', ''))
71 .join('|')
72 const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
73 function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
74 return isFileValid(files, avatarMimeTypesRegex, 'avatarfile', CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max)
75 }
76
77 // ---------------------------------------------------------------------------
78
79 export {
80 isUserVideosHistoryEnabledValid,
81 isUserBlockedValid,
82 isUserPasswordValid,
83 isUserBlockedReasonValid,
84 isUserRoleValid,
85 isUserVideoQuotaValid,
86 isUserVideoQuotaDailyValid,
87 isUserUsernameValid,
88 isUserEmailVerifiedValid,
89 isUserNSFWPolicyValid,
90 isUserWebTorrentEnabledValid,
91 isUserAutoPlayVideoValid,
92 isUserDisplayNameValid,
93 isUserDescriptionValid,
94 isAvatarFile
95 }