]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - server/helpers/custom-validators/users.ts
Optimize SQL requests of watch page API endpoints
[github/Chocobozzz/PeerTube.git] / server / helpers / custom-validators / users.ts
... / ...
CommitLineData
1import 'express-validator'
2import * as validator from 'validator'
3import { UserRole } from '../../../shared'
4import { CONSTRAINTS_FIELDS, NSFW_POLICY_TYPES } from '../../initializers'
5import { exists, isFileValid, isBooleanValid } from './misc'
6import { values } from 'lodash'
7
8const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
9
10function isUserPasswordValid (value: string) {
11 return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
12}
13
14function isUserVideoQuotaValid (value: string) {
15 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA)
16}
17
18function isUserVideoQuotaDailyValid (value: string) {
19 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA_DAILY)
20}
21
22function 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
28function isUserDisplayNameValid (value: string) {
29 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.NAME))
30}
31
32function isUserDescriptionValid (value: string) {
33 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.DESCRIPTION))
34}
35
36function isUserEmailVerifiedValid (value: any) {
37 return isBooleanValid(value)
38}
39
40const nsfwPolicies = values(NSFW_POLICY_TYPES)
41function isUserNSFWPolicyValid (value: any) {
42 return exists(value) && nsfwPolicies.indexOf(value) !== -1
43}
44
45function isUserAutoPlayVideoValid (value: any) {
46 return isBooleanValid(value)
47}
48
49function isUserBlockedValid (value: any) {
50 return isBooleanValid(value)
51}
52
53function isUserBlockedReasonValid (value: any) {
54 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
55}
56
57function isUserRoleValid (value: any) {
58 return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
59}
60
61const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
62 .map(v => v.replace('.', ''))
63 .join('|')
64const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
65function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
66 return isFileValid(files, avatarMimeTypesRegex, 'avatarfile', CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max)
67}
68
69// ---------------------------------------------------------------------------
70
71export {
72 isUserBlockedValid,
73 isUserPasswordValid,
74 isUserBlockedReasonValid,
75 isUserRoleValid,
76 isUserVideoQuotaValid,
77 isUserVideoQuotaDailyValid,
78 isUserUsernameValid,
79 isUserEmailVerifiedValid,
80 isUserNSFWPolicyValid,
81 isUserAutoPlayVideoValid,
82 isUserDisplayNameValid,
83 isUserDescriptionValid,
84 isAvatarFile
85}