X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Fcustom-validators%2Fmisc.ts;h=ebab4c6b244ba1277a0424c089e535fd9faac131;hb=2a4c0d8bbe29178ae90e776bb9453f86e6d23bd9;hp=1b7e00431094aef26d0d15369b7f53467e7171ea;hpb=c8861d5dc0436ef4342ce517241e3591fa256a13;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/custom-validators/misc.ts b/server/helpers/custom-validators/misc.ts index 1b7e00431..ebab4c6b2 100644 --- a/server/helpers/custom-validators/misc.ts +++ b/server/helpers/custom-validators/misc.ts @@ -1,7 +1,8 @@ import 'multer' -import * as validator from 'validator' +import { UploadFilesForCheck } from 'express' import { sep } from 'path' -import toBoolean = require('validator/lib/toBoolean') +import validator from 'validator' +import { isShortUUID, shortToUUID } from '@shared/extra-utils' function exists (value: any) { return value !== undefined && value !== null @@ -14,7 +15,11 @@ function isSafePath (p: string) { }) } -function isArray (value: any) { +function isSafePeerTubeFilenameWithoutExtension (filename: string) { + return filename.match(/^[a-z0-9-]+$/) +} + +function isArray (value: any): value is any[] { return Array.isArray(value) } @@ -22,6 +27,10 @@ function isNotEmptyIntArray (value: any) { return Array.isArray(value) && value.every(v => validator.isInt('' + v)) && value.length !== 0 } +function isNotEmptyStringArray (value: any) { + return Array.isArray(value) && value.every(v => typeof v === 'string' && v.length !== 0) && value.length !== 0 +} + function isArrayOf (value: any, validator: (value: any) => boolean) { return isArray(value) && value.every(v => validator(v)) } @@ -38,6 +47,10 @@ function isUUIDValid (value: string) { return exists(value) && validator.isUUID('' + value, 4) } +function areUUIDsValid (values: string[]) { + return isArray(values) && values.every(v => isUUIDValid(v)) +} + function isIdOrUUIDValid (value: string) { return isIdValid(value) || isUUIDValid(value) } @@ -46,13 +59,76 @@ function isBooleanValid (value: any) { return typeof value === 'boolean' || (typeof value === 'string' && validator.isBoolean(value)) } +function isIntOrNull (value: any) { + return value === null || validator.isInt('' + value) +} + +// --------------------------------------------------------------------------- + +function isFileValid (options: { + files: UploadFilesForCheck + + maxSize: number | null + mimeTypeRegex: string | null + + field?: string + + optional?: boolean // Default false +}) { + const { files, mimeTypeRegex, field, maxSize, optional = false } = options + + // Should have files + if (!files) return optional + + const fileArray = isArray(files) + ? files + : files[field] + + if (!fileArray || !isArray(fileArray) || fileArray.length === 0) { + return optional + } + + // The file exists + const file = fileArray[0] + if (!file?.originalname) return false + + // Check size + if ((maxSize !== null) && file.size > maxSize) return false + + if (mimeTypeRegex === null) return true + + return checkMimetypeRegex(file.mimetype, mimeTypeRegex) +} + +function checkMimetypeRegex (fileMimeType: string, mimeTypeRegex: string) { + return new RegExp(`^${mimeTypeRegex}$`, 'i').test(fileMimeType) +} + +// --------------------------------------------------------------------------- + +function toCompleteUUID (value: string) { + if (isShortUUID(value)) { + try { + return shortToUUID(value) + } catch { + return null + } + } + + return value +} + +function toCompleteUUIDs (values: string[]) { + return values.map(v => toCompleteUUID(v)) +} + function toIntOrNull (value: string) { const v = toValueOrNull(value) if (v === null || v === undefined) return v if (typeof v === 'number') return v - return validator.toInt(v) + return validator.toInt('' + v) } function toBooleanOrNull (value: any) { @@ -61,7 +137,7 @@ function toBooleanOrNull (value: any) { if (v === null || v === undefined) return v if (typeof v === 'boolean') return v - return toBoolean(v) + return validator.toBoolean('' + v) } function toValueOrNull (value: string) { @@ -70,12 +146,6 @@ function toValueOrNull (value: string) { return value } -function toArray (value: any) { - if (value && isArray(value) === false) return [ value ] - - return value -} - function toIntArray (value: any) { if (!value) return [] if (isArray(value) === false) return [ validator.toInt(value) ] @@ -83,33 +153,6 @@ function toIntArray (value: any) { return value.map(v => validator.toInt(v)) } -function isFileValid ( - files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[], - mimeTypeRegex: string, - field: string, - maxSize: number | null, - optional = false -) { - // Should have files - if (!files) return optional - if (isArray(files)) return optional - - // Should have a file - const fileArray = files[ field ] - if (!fileArray || fileArray.length === 0) { - return optional - } - - // The file should exist - const file = fileArray[ 0 ] - if (!file || !file.originalname) return false - - // Check size - if ((maxSize !== null) && file.size > maxSize) return false - - return new RegExp(`^${mimeTypeRegex}$`, 'i').test(file.mimetype) -} - // --------------------------------------------------------------------------- export { @@ -117,16 +160,22 @@ export { isArrayOf, isNotEmptyIntArray, isArray, + isIntOrNull, isIdValid, isSafePath, + isNotEmptyStringArray, isUUIDValid, + toCompleteUUIDs, + toCompleteUUID, isIdOrUUIDValid, isDateValid, toValueOrNull, toBooleanOrNull, isBooleanValid, toIntOrNull, - toArray, + areUUIDsValid, toIntArray, - isFileValid + isFileValid, + isSafePeerTubeFilenameWithoutExtension, + checkMimetypeRegex }