]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame_incremental - server/helpers/custom-validators/videos.ts
Fix client compilation
[github/Chocobozzz/PeerTube.git] / server / helpers / custom-validators / videos.ts
... / ...
CommitLineData
1import { values } from 'lodash'
2import * as validator from 'validator'
3import 'multer'
4
5import {
6 CONSTRAINTS_FIELDS,
7 VIDEO_CATEGORIES,
8 VIDEO_LICENCES,
9 VIDEO_LANGUAGES,
10 VIDEO_RATE_TYPES
11} from '../../initializers'
12import { isUserUsernameValid } from './users'
13import { isArray, exists } from './misc'
14import { VideoRateType } from '../../../shared'
15
16const VIDEOS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.VIDEOS
17const VIDEO_ABUSES_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.VIDEO_ABUSES
18const VIDEO_EVENTS_CONSTRAINTS_FIELDS = CONSTRAINTS_FIELDS.VIDEO_EVENTS
19
20function isVideoAuthorValid (value: string) {
21 return isUserUsernameValid(value)
22}
23
24function isVideoDateValid (value: string) {
25 return exists(value) && validator.isISO8601(value)
26}
27
28function isVideoCategoryValid (value: number) {
29 return VIDEO_CATEGORIES[value] !== undefined
30}
31
32function isVideoLicenceValid (value: number) {
33 return VIDEO_LICENCES[value] !== undefined
34}
35
36function isVideoLanguageValid (value: number) {
37 return value === null || VIDEO_LANGUAGES[value] !== undefined
38}
39
40function isVideoNSFWValid (value: any) {
41 return typeof value === 'boolean' || (typeof value === 'string' && validator.isBoolean(value))
42}
43
44function isVideoDescriptionValid (value: string) {
45 return exists(value) && validator.isLength(value, VIDEOS_CONSTRAINTS_FIELDS.DESCRIPTION)
46}
47
48function isVideoDurationValid (value: string) {
49 return exists(value) && validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.DURATION)
50}
51
52function isVideoExtnameValid (value: string) {
53 return VIDEOS_CONSTRAINTS_FIELDS.EXTNAME.indexOf(value) !== -1
54}
55
56function isVideoInfoHashValid (value: string) {
57 return exists(value) && validator.isLength(value, VIDEOS_CONSTRAINTS_FIELDS.INFO_HASH)
58}
59
60function isVideoNameValid (value: string) {
61 return exists(value) && validator.isLength(value, VIDEOS_CONSTRAINTS_FIELDS.NAME)
62}
63
64function isVideoTagsValid (tags: string[]) {
65 return isArray(tags) &&
66 validator.isInt(tags.length.toString(), VIDEOS_CONSTRAINTS_FIELDS.TAGS) &&
67 tags.every(function (tag) {
68 return exists(tag) && validator.isLength(tag, VIDEOS_CONSTRAINTS_FIELDS.TAG)
69 })
70}
71
72function isVideoThumbnailValid (value: string) {
73 return exists(value) && validator.isLength(value, VIDEOS_CONSTRAINTS_FIELDS.THUMBNAIL)
74}
75
76function isVideoThumbnailDataValid (value: string) {
77 return exists(value) && validator.isByteLength(value, VIDEOS_CONSTRAINTS_FIELDS.THUMBNAIL_DATA)
78}
79
80function isVideoRemoteIdValid (value: string) {
81 return exists(value) && validator.isUUID(value, 4)
82}
83
84function isVideoAbuseReasonValid (value: string) {
85 return exists(value) && validator.isLength(value, VIDEO_ABUSES_CONSTRAINTS_FIELDS.REASON)
86}
87
88function isVideoAbuseReporterUsernameValid (value: string) {
89 return isUserUsernameValid(value)
90}
91
92function isVideoViewsValid (value: string) {
93 return exists(value) && validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.VIEWS)
94}
95
96function isVideoLikesValid (value: string) {
97 return exists(value) && validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.LIKES)
98}
99
100function isVideoDislikesValid (value: string) {
101 return exists(value) && validator.isInt(value + '', VIDEOS_CONSTRAINTS_FIELDS.DISLIKES)
102}
103
104function isVideoEventCountValid (value: string) {
105 return exists(value) && validator.isInt(value + '', VIDEO_EVENTS_CONSTRAINTS_FIELDS.COUNT)
106}
107
108function isVideoRatingTypeValid (value: string) {
109 return values(VIDEO_RATE_TYPES).indexOf(value as VideoRateType) !== -1
110}
111
112function isVideoFile (value: string, files: { [ fieldname: string ]: Express.Multer.File[] }) {
113 // Should have files
114 if (!files) return false
115
116 // Should have videofile file
117 const videofile = files.videofile
118 if (!videofile || videofile.length === 0) return false
119
120 // The file should exist
121 const file = videofile[0]
122 if (!file || !file.originalname) return false
123
124 return new RegExp('^video/(webm|mp4|ogg)$', 'i').test(file.mimetype)
125}
126
127// ---------------------------------------------------------------------------
128
129export {
130 isVideoAuthorValid,
131 isVideoDateValid,
132 isVideoCategoryValid,
133 isVideoLicenceValid,
134 isVideoLanguageValid,
135 isVideoNSFWValid,
136 isVideoDescriptionValid,
137 isVideoDurationValid,
138 isVideoInfoHashValid,
139 isVideoNameValid,
140 isVideoTagsValid,
141 isVideoThumbnailValid,
142 isVideoThumbnailDataValid,
143 isVideoExtnameValid,
144 isVideoRemoteIdValid,
145 isVideoAbuseReasonValid,
146 isVideoAbuseReporterUsernameValid,
147 isVideoFile,
148 isVideoViewsValid,
149 isVideoLikesValid,
150 isVideoRatingTypeValid,
151 isVideoDislikesValid,
152 isVideoEventCountValid
153}
154
155declare global {
156 namespace ExpressValidator {
157 export interface Validator {
158 isVideoAuthorValid,
159 isVideoDateValid,
160 isVideoCategoryValid,
161 isVideoLicenceValid,
162 isVideoLanguageValid,
163 isVideoNSFWValid,
164 isVideoDescriptionValid,
165 isVideoDurationValid,
166 isVideoInfoHashValid,
167 isVideoNameValid,
168 isVideoTagsValid,
169 isVideoThumbnailValid,
170 isVideoThumbnailDataValid,
171 isVideoExtnameValid,
172 isVideoRemoteIdValid,
173 isVideoAbuseReasonValid,
174 isVideoAbuseReporterUsernameValid,
175 isVideoFile,
176 isVideoViewsValid,
177 isVideoLikesValid,
178 isVideoRatingTypeValid,
179 isVideoDislikesValid,
180 isVideoEventCountValid
181 }
182 }
183}