const usersValidators = require('./users')
const miscValidators = require('./misc')
const VIDEOS_CONSTRAINTS_FIELDS = constants.CONSTRAINTS_FIELDS.VIDEOS
+const VIDEO_ABUSES_CONSTRAINTS_FIELDS = constants.CONSTRAINTS_FIELDS.VIDEO_ABUSES
+const VIDEO_EVENTS_CONSTRAINTS_FIELDS = constants.CONSTRAINTS_FIELDS.VIDEO_EVENTS
const videosValidators = {
- isEachRemoteVideosValid,
isVideoAuthorValid,
isVideoDateValid,
isVideoDescriptionValid,
isVideoNameValid,
isVideoTagsValid,
isVideoThumbnailValid,
- isVideoThumbnailDataValid
-}
-
-function isEachRemoteVideosValid (requests) {
- return miscValidators.isArray(requests) &&
- requests.every(function (request) {
- const video = request.data
- return (
- isRequestTypeAddValid(request.type) &&
- isVideoAuthorValid(video.author) &&
- isVideoDateValid(video.createdAt) &&
- isVideoDateValid(video.updatedAt) &&
- isVideoDescriptionValid(video.description) &&
- isVideoDurationValid(video.duration) &&
- isVideoInfoHashValid(video.infoHash) &&
- isVideoNameValid(video.name) &&
- isVideoTagsValid(video.tags) &&
- isVideoThumbnailDataValid(video.thumbnailData) &&
- isVideoRemoteIdValid(video.remoteId) &&
- isVideoExtnameValid(video.extname)
- ) ||
- (
- isRequestTypeUpdateValid(request.type) &&
- isVideoDateValid(video.createdAt) &&
- isVideoDateValid(video.updatedAt) &&
- isVideoDescriptionValid(video.description) &&
- isVideoDurationValid(video.duration) &&
- isVideoInfoHashValid(video.infoHash) &&
- isVideoNameValid(video.name) &&
- isVideoTagsValid(video.tags) &&
- isVideoRemoteIdValid(video.remoteId) &&
- isVideoExtnameValid(video.extname)
- ) ||
- (
- isRequestTypeRemoveValid(request.type) &&
- isVideoNameValid(video.name) &&
- isVideoRemoteIdValid(video.remoteId)
- )
- })
+ isVideoThumbnailDataValid,
+ isVideoExtnameValid,
+ isVideoRemoteIdValid,
+ isVideoAbuseReasonValid,
+ isVideoAbuseReporterUsernameValid,
+ isVideoFile,
+ isVideoViewsValid,
+ isVideoLikesValid,
+ isVideoDislikesValid,
+ isVideoEventCountValid
}
function isVideoAuthorValid (value) {
return validator.isUUID(value, 4)
}
-// ---------------------------------------------------------------------------
+function isVideoAbuseReasonValid (value) {
+ return validator.isLength(value, VIDEO_ABUSES_CONSTRAINTS_FIELDS.REASON)
+}
-module.exports = videosValidators
+function isVideoAbuseReporterUsernameValid (value) {
+ return usersValidators.isUserUsernameValid(value)
+}
-// ---------------------------------------------------------------------------
+function isVideoViewsValid (value) {
+ return validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.VIEWS)
+}
+
+function isVideoLikesValid (value) {
+ return validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.LIKES)
+}
-function isRequestTypeAddValid (value) {
- return value === 'add'
+function isVideoDislikesValid (value) {
+ return validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.DISLIKES)
}
-function isRequestTypeUpdateValid (value) {
- return value === 'update'
+function isVideoEventCountValid (value) {
+ return validator.isInt(value + '', VIDEO_EVENTS_CONSTRAINTS_FIELDS.COUNT)
}
-function isRequestTypeRemoveValid (value) {
- return value === 'remove'
+function isVideoFile (value, files) {
+ // Should have files
+ if (!files) return false
+
+ // Should have videofile file
+ const videofile = files.videofile
+ if (!videofile || videofile.length === 0) return false
+
+ // The file should exist
+ const file = videofile[0]
+ if (!file || !file.originalname) return false
+
+ return new RegExp('^video/(webm|mp4|ogg)$', 'i').test(file.mimetype)
}
+
+// ---------------------------------------------------------------------------
+
+module.exports = videosValidators