1
0
Fork 0
peertube/server/helpers/custom-validators/users.ts

101 lines
3.1 KiB
TypeScript
Raw Normal View History

2017-09-07 13:27:35 +00:00
import 'express-validator'
import * as validator from 'validator'
import { UserRole } from '../../../shared'
import { CONSTRAINTS_FIELDS, NSFW_POLICY_TYPES } from '../../initializers/constants'
import { exists, isBooleanValid, isFileValid } from './misc'
import { values } from 'lodash'
2017-06-16 08:36:18 +00:00
2017-05-15 20:22:03 +00:00
const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
2016-07-31 18:58:43 +00:00
2017-06-10 20:15:25 +00:00
function isUserPasswordValid (value: string) {
return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
}
2017-09-04 18:07:54 +00:00
function isUserVideoQuotaValid (value: string) {
return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA)
}
function isUserVideoQuotaDailyValid (value: string) {
return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA_DAILY)
}
2017-06-10 20:15:25 +00:00
function isUserUsernameValid (value: string) {
const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
2017-11-04 17:32:38 +00:00
return exists(value) && validator.matches(value, new RegExp(`^[a-z0-9._]{${min},${max}}$`))
2016-07-31 18:58:43 +00:00
}
function isUserDisplayNameValid (value: string) {
return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.NAME))
}
function isUserDescriptionValid (value: string) {
return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.DESCRIPTION))
}
function isUserEmailVerifiedValid (value: any) {
return isBooleanValid(value)
}
const nsfwPolicies = values(NSFW_POLICY_TYPES)
function isUserNSFWPolicyValid (value: any) {
return exists(value) && nsfwPolicies.indexOf(value) !== -1
}
2018-10-12 16:12:39 +00:00
function isUserWebTorrentEnabledValid (value: any) {
return isBooleanValid(value)
}
function isUserVideosHistoryEnabledValid (value: any) {
return isBooleanValid(value)
}
function isUserAutoPlayVideoValid (value: any) {
2018-08-08 12:58:21 +00:00
return isBooleanValid(value)
}
2019-04-15 08:49:46 +00:00
function isUserAdminFlagsValid (value: any) {
return exists(value) && validator.isInt('' + value)
}
2018-08-08 12:58:21 +00:00
function isUserBlockedValid (value: any) {
return isBooleanValid(value)
}
2018-08-08 15:36:10 +00:00
function isUserBlockedReasonValid (value: any) {
return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
}
function isUserRoleValid (value: any) {
return exists(value) && validator.isInt('' + value) && UserRole[value] !== undefined
}
const avatarMimeTypes = CONSTRAINTS_FIELDS.ACTORS.AVATAR.EXTNAME
.map(v => v.replace('.', ''))
.join('|')
const avatarMimeTypesRegex = `image/(${avatarMimeTypes})`
2017-12-29 18:10:13 +00:00
function isAvatarFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) {
2018-06-22 13:42:55 +00:00
return isFileValid(files, avatarMimeTypesRegex, 'avatarfile', CONSTRAINTS_FIELDS.ACTORS.AVATAR.FILE_SIZE.max)
2017-12-29 18:10:13 +00:00
}
2016-07-31 18:58:43 +00:00
// ---------------------------------------------------------------------------
2017-05-15 20:22:03 +00:00
export {
isUserVideosHistoryEnabledValid,
2018-08-08 12:58:21 +00:00
isUserBlockedValid,
2017-05-15 20:22:03 +00:00
isUserPasswordValid,
2018-08-08 15:36:10 +00:00
isUserBlockedReasonValid,
2017-05-15 20:22:03 +00:00
isUserRoleValid,
2017-09-04 18:07:54 +00:00
isUserVideoQuotaValid,
isUserVideoQuotaDailyValid,
2017-05-15 20:22:03 +00:00
isUserUsernameValid,
2019-04-15 08:49:46 +00:00
isUserAdminFlagsValid,
isUserEmailVerifiedValid,
isUserNSFWPolicyValid,
2018-10-12 16:12:39 +00:00
isUserWebTorrentEnabledValid,
2017-12-29 18:10:13 +00:00
isUserAutoPlayVideoValid,
isUserDisplayNameValid,
isUserDescriptionValid,
2017-12-29 18:10:13 +00:00
isAvatarFile
2017-05-15 20:22:03 +00:00
}