Add ability to set video thumbnail/preview
[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 } from '../../initializers'
5
6 import { exists, isFileValid } from './misc'
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 isBoolean (value: any) {
25   return typeof value === 'boolean' || (typeof value === 'string' && validator.isBoolean(value))
26 }
27
28 function isUserDisplayNSFWValid (value: any) {
29   return isBoolean(value)
30 }
31
32 function isUserAutoPlayVideoValid (value: any) {
33   return isBoolean(value)
34 }
35
36 function isUserRoleValid (value: any) {
37   return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
38 }
39
40 const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
41   .map(v => v.replace('.', ''))
42   .join('|')
43 const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
44 function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
45   return isFileValid(files, avatarMimeTypesRegex, 'avatarfile')
46 }
47
48 // ---------------------------------------------------------------------------
49
50 export {
51   isUserPasswordValid,
52   isUserRoleValid,
53   isUserVideoQuotaValid,
54   isUserUsernameValid,
55   isUserDisplayNSFWValid,
56   isUserAutoPlayVideoValid,
57   isAvatarFile
58 }