1 import * as validator from 'validator'
2 import { UserRole } from '../../../shared'
3 import { CONSTRAINTS_FIELDS, NSFW_POLICY_TYPES } from '../../initializers/constants'
4 import { exists, isArray, isBooleanValid, isFileValid } from './misc'
5 import { values } from 'lodash'
7 const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
9 function isUserPasswordValid (value: string) {
10 return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
13 function isUserVideoQuotaValid (value: string) {
14 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA)
17 function isUserVideoQuotaDailyValid (value: string) {
18 return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA_DAILY)
21 function isUserUsernameValid (value: string) {
22 const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
23 const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
24 return exists(value) && validator.matches(value, new RegExp(`^[a-z0-9._]{${min},${max}}$`))
27 function isUserDisplayNameValid (value: string) {
28 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.NAME))
31 function isUserDescriptionValid (value: string) {
32 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.DESCRIPTION))
35 function isUserEmailVerifiedValid (value: any) {
36 return isBooleanValid(value)
39 const nsfwPolicies = values(NSFW_POLICY_TYPES)
40 function isUserNSFWPolicyValid (value: any) {
41 return exists(value) && nsfwPolicies.indexOf(value) !== -1
44 function isUserWebTorrentEnabledValid (value: any) {
45 return isBooleanValid(value)
48 function isUserVideosHistoryEnabledValid (value: any) {
49 return isBooleanValid(value)
52 function isUserAutoPlayVideoValid (value: any) {
53 return isBooleanValid(value)
56 function isUserVideoLanguages (value: any) {
57 return value === null || (isArray(value) && value.length < CONSTRAINTS_FIELDS.USERS.VIDEO_LANGUAGES.max)
60 function isUserAdminFlagsValid (value: any) {
61 return exists(value) && validator.isInt('' + value)
64 function isUserBlockedValid (value: any) {
65 return isBooleanValid(value)
68 function isNoInstanceConfigWarningModal (value: any) {
69 return isBooleanValid(value)
72 function isNoWelcomeModal (value: any) {
73 return isBooleanValid(value)
76 function isUserBlockedReasonValid (value: any) {
77 return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
80 function isUserRoleValid (value: any) {
81 return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
84 const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
85 .map(v => v.replace('.', ''))
87 const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
88 function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
89 return isFileValid(files, avatarMimeTypesRegex, 'avatarfile', CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max)
92 // ---------------------------------------------------------------------------
95 isUserVideosHistoryEnabledValid,
99 isUserBlockedReasonValid,
101 isUserVideoQuotaValid,
102 isUserVideoQuotaDailyValid,
104 isUserAdminFlagsValid,
105 isUserEmailVerifiedValid,
106 isUserNSFWPolicyValid,
107 isUserWebTorrentEnabledValid,
108 isUserAutoPlayVideoValid,
109 isUserDisplayNameValid,
110 isUserDescriptionValid,
111 isNoInstanceConfigWarningModal,