X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fcontrollers%2Flazy-static.ts;h=25d3b49b4655d2ebf788b37c9bc2dc2872635ccc;hb=012580d98f489e599d44a9a2a0bdc892b9455a90;hp=4285fd727f0938fc99defb9d4f4a19deb13fe0b7;hpb=557b13ae24019d9ab214bbea7eaa0f892c8f4b05;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/lazy-static.ts b/server/controllers/lazy-static.ts index 4285fd727..25d3b49b4 100644 --- a/server/controllers/lazy-static.ts +++ b/server/controllers/lazy-static.ts @@ -1,11 +1,13 @@ import * as cors from 'cors' import * as express from 'express' +import { VideosTorrentCache } from '@server/lib/files-cache/videos-torrent-cache' +import { HttpStatusCode } from '../../shared/core-utils/miscs/http-error-codes' +import { logger } from '../helpers/logger' import { LAZY_STATIC_PATHS, STATIC_MAX_AGE } from '../initializers/constants' +import { actorImagePathUnsafeCache, pushActorImageProcessInQueue } from '../lib/actor-image' import { VideosCaptionCache, VideosPreviewCache } from '../lib/files-cache' import { asyncMiddleware } from '../middlewares' -import { AvatarModel } from '../models/avatar/avatar' -import { logger } from '../helpers/logger' -import { avatarPathUnsafeCache, pushAvatarProcessInQueue } from '../lib/avatar' +import { ActorImageModel } from '../models/actor/actor-image' const lazyStaticRouter = express.Router() @@ -13,19 +15,29 @@ lazyStaticRouter.use(cors()) lazyStaticRouter.use( LAZY_STATIC_PATHS.AVATARS + ':filename', - asyncMiddleware(getAvatar) + asyncMiddleware(getActorImage) ) lazyStaticRouter.use( - LAZY_STATIC_PATHS.PREVIEWS + ':uuid.jpg', + LAZY_STATIC_PATHS.BANNERS + ':filename', + asyncMiddleware(getActorImage) +) + +lazyStaticRouter.use( + LAZY_STATIC_PATHS.PREVIEWS + ':filename', asyncMiddleware(getPreview) ) lazyStaticRouter.use( - LAZY_STATIC_PATHS.VIDEO_CAPTIONS + ':videoId-:captionLanguage([a-z]+).vtt', + LAZY_STATIC_PATHS.VIDEO_CAPTIONS + ':filename', asyncMiddleware(getVideoCaption) ) +lazyStaticRouter.use( + LAZY_STATIC_PATHS.TORRENTS + ':filename', + asyncMiddleware(getTorrent) +) + // --------------------------------------------------------------------------- export { @@ -36,45 +48,57 @@ export { // --------------------------------------------------------------------------- -async function getAvatar (req: express.Request, res: express.Response) { +async function getActorImage (req: express.Request, res: express.Response) { const filename = req.params.filename - if (avatarPathUnsafeCache.has(filename)) { - return res.sendFile(avatarPathUnsafeCache.get(filename), { maxAge: STATIC_MAX_AGE.SERVER }) + if (actorImagePathUnsafeCache.has(filename)) { + return res.sendFile(actorImagePathUnsafeCache.get(filename), { maxAge: STATIC_MAX_AGE.SERVER }) } - const avatar = await AvatarModel.loadByName(filename) - if (avatar.onDisk === false) { - if (!avatar.fileUrl) return res.sendStatus(404) + const image = await ActorImageModel.loadByName(filename) + if (!image) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + + if (image.onDisk === false) { + if (!image.fileUrl) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) - logger.info('Lazy serve remote avatar image %s.', avatar.fileUrl) + logger.info('Lazy serve remote actor image %s.', image.fileUrl) - await pushAvatarProcessInQueue({ filename: avatar.filename, fileUrl: avatar.fileUrl }) + try { + await pushActorImageProcessInQueue({ filename: image.filename, fileUrl: image.fileUrl, type: image.type }) + } catch (err) { + logger.warn('Cannot process remote actor image %s.', image.fileUrl, { err }) + return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + } - avatar.onDisk = true - avatar.save() - .catch(err => logger.error('Cannot save new avatar disk state.', { err })) + image.onDisk = true + image.save() + .catch(err => logger.error('Cannot save new actor image disk state.', { err })) } - const path = avatar.getPath() + const path = image.getPath() - avatarPathUnsafeCache.set(filename, path) - return res.sendFile(path, { maxAge: STATIC_MAX_AGE.SERVER }) + actorImagePathUnsafeCache.set(filename, path) + return res.sendFile(path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }) } async function getPreview (req: express.Request, res: express.Response) { - const result = await VideosPreviewCache.Instance.getFilePath(req.params.uuid) - if (!result) return res.sendStatus(404) + const result = await VideosPreviewCache.Instance.getFilePath(req.params.filename) + if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) - return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.SERVER }) + return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }) } async function getVideoCaption (req: express.Request, res: express.Response) { - const result = await VideosCaptionCache.Instance.getFilePath({ - videoId: req.params.videoId, - language: req.params.captionLanguage - }) - if (!result) return res.sendStatus(404) + const result = await VideosCaptionCache.Instance.getFilePath(req.params.filename) + if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + + return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }) +} + +async function getTorrent (req: express.Request, res: express.Response) { + const result = await VideosTorrentCache.Instance.getFilePath(req.params.filename) + if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + // Torrents still use the old naming convention (video uuid + .torrent) return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.SERVER }) }