PeerTube/server/helpers/custom-validators/users.ts

42 lines
1.2 KiB
TypeScript
Raw Normal View History

2017-05-15 22:22:03 +02:00
import { values } from 'lodash'
2017-06-05 21:53:49 +02:00
import * as validator from 'validator'
2017-09-07 15:27:35 +02:00
import 'express-validator'
2016-07-31 20:58:43 +02:00
2017-06-10 22:15:25 +02:00
import { exists } from './misc'
2017-05-15 22:22:03 +02:00
import { CONSTRAINTS_FIELDS, USER_ROLES } from '../../initializers'
2017-06-16 10:36:18 +02:00
import { UserRole } from '../../../shared'
2017-05-15 22:22:03 +02:00
const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
2016-07-31 20:58:43 +02:00
2017-06-10 22:15:25 +02:00
function isUserPasswordValid (value: string) {
return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
}
2017-06-10 22:15:25 +02:00
function isUserRoleValid (value: string) {
2017-06-16 10:36:18 +02:00
return values(USER_ROLES).indexOf(value as UserRole) !== -1
}
2017-09-04 20:07:54 +02:00
function isUserVideoQuotaValid (value: string) {
return exists(value) && validator.isInt(value + '', USERS_CONSTRAINTS_FIELDS.VIDEO_QUOTA)
}
2017-06-10 22:15:25 +02:00
function isUserUsernameValid (value: string) {
const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
2017-06-10 22:15:25 +02:00
return exists(value) && validator.matches(value, new RegExp(`^[a-zA-Z0-9._]{${min},${max}}$`))
2016-07-31 20:58:43 +02:00
}
2017-06-10 22:15:25 +02:00
function isUserDisplayNSFWValid (value: any) {
return typeof value === 'boolean' || (typeof value === 'string' && validator.isBoolean(value))
2017-04-03 21:24:36 +02:00
}
2016-07-31 20:58:43 +02:00
// ---------------------------------------------------------------------------
2017-05-15 22:22:03 +02:00
export {
isUserPasswordValid,
isUserRoleValid,
2017-09-04 20:07:54 +02:00
isUserVideoQuotaValid,
2017-05-15 22:22:03 +02:00
isUserUsernameValid,
isUserDisplayNSFWValid
}