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

120 lines
3.5 KiB
TypeScript
Raw Normal View History

2021-04-06 11:01:35 -04:00
import { values } from 'lodash'
2020-01-07 08:56:07 -05:00
import validator from 'validator'
2021-12-24 04:14:47 -05:00
import { UserRole } from '@shared/models'
2021-04-06 11:01:35 -04:00
import { isEmailEnabled } from '../../initializers/config'
import { CONSTRAINTS_FIELDS, NSFW_POLICY_TYPES } from '../../initializers/constants'
2021-04-07 04:36:13 -04:00
import { exists, isArray, isBooleanValid } from './misc'
2017-06-16 04:36:18 -04:00
2017-05-15 16:22:03 -04:00
const USERS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.USERS
2016-07-31 14:58:43 -04:00
2017-06-10 16:15:25 -04:00
function isUserPasswordValid (value: string) {
return validator.isLength(value, USERS_CONSTRAINTS_FIELDS.PASSWORD)
}
function isUserPasswordValidOrEmpty (value: string) {
// Empty password is only possible if emailing is enabled.
2020-02-17 04:27:00 -05:00
if (value === '') return isEmailEnabled()
return isUserPasswordValid(value)
}
2017-09-04 14:07:54 -04: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 16:15:25 -04:00
function isUserUsernameValid (value: string) {
const max = USERS_CONSTRAINTS_FIELDS.USERNAME.max
const min = USERS_CONSTRAINTS_FIELDS.USERNAME.min
2017-11-04 13:32:38 -04:00
return exists(value) && validator.matches(value, new RegExp(`^[a-z0-9._]{${min},${max}}$`))
2016-07-31 14:58:43 -04: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) {
2020-02-28 10:03:39 -05:00
return exists(value) && nsfwPolicies.includes(value)
}
function isUserP2PEnabledValid (value: any) {
2018-10-12 12:12:39 -04:00
return isBooleanValid(value)
}
function isUserVideosHistoryEnabledValid (value: any) {
return isBooleanValid(value)
}
function isUserAutoPlayVideoValid (value: any) {
2018-08-08 08:58:21 -04:00
return isBooleanValid(value)
}
function isUserVideoLanguages (value: any) {
return value === null || (isArray(value) && value.length < CONSTRAINTS_FIELDS.USERS.VIDEO_LANGUAGES.max)
}
2019-04-15 04:49:46 -04:00
function isUserAdminFlagsValid (value: any) {
return exists(value) && validator.isInt('' + value)
}
2018-08-08 08:58:21 -04:00
function isUserBlockedValid (value: any) {
return isBooleanValid(value)
}
function isUserAutoPlayNextVideoValid (value: any) {
return isBooleanValid(value)
}
function isUserAutoPlayNextVideoPlaylistValid (value: any) {
return isBooleanValid(value)
}
function isUserNoModal (value: any) {
2019-08-28 08:40:06 -04:00
return isBooleanValid(value)
}
2018-08-08 11:36:10 -04:00
function isUserBlockedReasonValid (value: any) {
return value === null || (exists(value) && validator.isLength(value, CONSTRAINTS_FIELDS.USERS.BLOCKED_REASON))
}
function isUserRoleValid (value: any) {
2021-12-28 09:30:36 -05:00
return exists(value) && validator.isInt('' + value) && [ UserRole.ADMINISTRATOR, UserRole.MODERATOR, UserRole.USER ].includes(value)
}
2016-07-31 14:58:43 -04:00
// ---------------------------------------------------------------------------
2017-05-15 16:22:03 -04:00
export {
isUserVideosHistoryEnabledValid,
2018-08-08 08:58:21 -04:00
isUserBlockedValid,
2017-05-15 16:22:03 -04:00
isUserPasswordValid,
isUserPasswordValidOrEmpty,
isUserVideoLanguages,
2018-08-08 11:36:10 -04:00
isUserBlockedReasonValid,
2017-05-15 16:22:03 -04:00
isUserRoleValid,
2017-09-04 14:07:54 -04:00
isUserVideoQuotaValid,
isUserVideoQuotaDailyValid,
2017-05-15 16:22:03 -04:00
isUserUsernameValid,
2019-04-15 04:49:46 -04:00
isUserAdminFlagsValid,
isUserEmailVerifiedValid,
isUserNSFWPolicyValid,
isUserP2PEnabledValid,
2017-12-29 13:10:13 -05:00
isUserAutoPlayVideoValid,
isUserAutoPlayNextVideoValid,
isUserAutoPlayNextVideoPlaylistValid,
isUserDisplayNameValid,
isUserDescriptionValid,
isUserNoModal
2017-05-15 16:22:03 -04:00
}