X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fhelpers%2Fcustom-validators%2Fvideo-imports.ts;h=4d6ab1fa41cf6578300bcb45292808f56ce281cf;hb=e78980ebd116be1ea901387c126876af902191e6;hp=36c0559fd82326019e89531f0014c038ff74f742;hpb=fbad87b0472f574409f7aa3ae7f8b54927d0cdd6;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/helpers/custom-validators/video-imports.ts b/server/helpers/custom-validators/video-imports.ts index 36c0559fd..4d6ab1fa4 100644 --- a/server/helpers/custom-validators/video-imports.ts +++ b/server/helpers/custom-validators/video-imports.ts @@ -1,8 +1,10 @@ import 'express-validator' import 'multer' import * as validator from 'validator' -import { CONSTRAINTS_FIELDS, VIDEO_IMPORT_STATES } from '../../initializers' -import { exists } from './misc' +import { CONSTRAINTS_FIELDS, TORRENT_MIMETYPE_EXT, VIDEO_IMPORT_STATES } from '../../initializers' +import { exists, isFileValid } from './misc' +import * as express from 'express' +import { VideoImportModel } from '../../models/video/video-import' function isVideoImportTargetUrlValid (url: string) { const isURLOptions = { @@ -22,9 +24,32 @@ function isVideoImportStateValid (value: any) { return exists(value) && VIDEO_IMPORT_STATES[ value ] !== undefined } +const videoTorrentImportTypes = Object.keys(TORRENT_MIMETYPE_EXT).map(m => `(${m})`) +const videoTorrentImportRegex = videoTorrentImportTypes.join('|') +function isVideoImportTorrentFile (files: { [ fieldname: string ]: Express.Multer.File[] } | Express.Multer.File[]) { + return isFileValid(files, videoTorrentImportRegex, 'torrentfile', CONSTRAINTS_FIELDS.VIDEO_IMPORTS.TORRENT_FILE.FILE_SIZE.max, true) +} + +async function isVideoImportExist (id: number, res: express.Response) { + const videoImport = await VideoImportModel.loadAndPopulateVideo(id) + + if (!videoImport) { + res.status(404) + .json({ error: 'Video import not found' }) + .end() + + return false + } + + res.locals.videoImport = videoImport + return true +} + // --------------------------------------------------------------------------- export { isVideoImportStateValid, - isVideoImportTargetUrlValid + isVideoImportTargetUrlValid, + isVideoImportExist, + isVideoImportTorrentFile }