Add reason when banning a user
[oweals/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 isUserUsernameValid (value: string) {
19   const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
20   const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
21   return exists(value) && validator.matches(value, new RegExp(`^[a-z0-9._]{${min},${max}}$`))
22 }
23
24 function isUserDisplayNameValid (value: string) {
25   return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.NAME))
26 }
27
28 function isUserDescriptionValid (value: string) {
29   return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.DESCRIPTION))
30 }
31
32 const nsfwPolicies = values(NSFW_POLICY_TYPES)
33 function isUserNSFWPolicyValid (value: any) {
34   return exists(value) && nsfwPolicies.indexOf(value) !== -1
35 }
36
37 function isUserAutoPlayVideoValid (value: any) {
38   return isBooleanValid(value)
39 }
40
41 function isUserBlockedValid (value: any) {
42   return isBooleanValid(value)
43 }
44
45 function isUserBlockedReasonValid (value: any) {
46   return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
47 }
48
49 function isUserRoleValid (value: any) {
50   return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
51 }
52
53 const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
54   .map(v => v.replace('.', ''))
55   .join('|')
56 const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
57 function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
58   return isFileValid(files, avatarMimeTypesRegex, 'avatarfile', CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max)
59 }
60
61 // ---------------------------------------------------------------------------
62
63 export {
64   isUserBlockedValid,
65   isUserPasswordValid,
66   isUserBlockedReasonValid,
67   isUserRoleValid,
68   isUserVideoQuotaValid,
69   isUserUsernameValid,
70   isUserNSFWPolicyValid,
71   isUserAutoPlayVideoValid,
72   isUserDisplayNameValid,
73   isUserDescriptionValid,
74   isAvatarFile
75 }