X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;ds=sidebyside;f=server%2Fcontrollers%2Flazy-static.ts;h=632e4dcd8d6f5b7f5d72368541e6cb6e6f3b014c;hb=c0e8b12e7fd554ba4d2ceb0c4900804c6a4c63ea;hp=25d3b49b4655d2ebf788b37c9bc2dc2872635ccc;hpb=1c5e49e75284100b7b1fc8b4e73c8ba53fe22e89;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/controllers/lazy-static.ts b/server/controllers/lazy-static.ts index 25d3b49b4..632e4dcd8 100644 --- a/server/controllers/lazy-static.ts +++ b/server/controllers/lazy-static.ts @@ -1,11 +1,11 @@ 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 { HttpStatusCode } from '../../shared/models/http/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 { actorImagePathUnsafeCache, pushActorImageProcessInQueue } from '../lib/local-actor' import { asyncMiddleware } from '../middlewares' import { ActorImageModel } from '../models/actor/actor-image' @@ -48,7 +48,7 @@ export { // --------------------------------------------------------------------------- -async function getActorImage (req: express.Request, res: express.Response) { +async function getActorImage (req: express.Request, res: express.Response, next: express.NextFunction) { const filename = req.params.filename if (actorImagePathUnsafeCache.has(filename)) { @@ -56,10 +56,10 @@ async function getActorImage (req: express.Request, res: express.Response) { } const image = await ActorImageModel.loadByName(filename) - if (!image) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + if (!image) return res.status(HttpStatusCode.NOT_FOUND_404).end() if (image.onDisk === false) { - if (!image.fileUrl) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + if (!image.fileUrl) return res.status(HttpStatusCode.NOT_FOUND_404).end() logger.info('Lazy serve remote actor image %s.', image.fileUrl) @@ -67,7 +67,7 @@ async function getActorImage (req: express.Request, res: express.Response) { 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) + return res.status(HttpStatusCode.NOT_FOUND_404).end() } image.onDisk = true @@ -78,26 +78,42 @@ async function getActorImage (req: express.Request, res: express.Response) { const path = image.getPath() actorImagePathUnsafeCache.set(filename, path) - return res.sendFile(path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }) + + return res.sendFile(path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }, (err: any) => { + if (!err) return + + // It seems this actor image is not on the disk anymore + if (err.status === HttpStatusCode.NOT_FOUND_404 && !image.isOwned()) { + logger.error('Cannot lazy serve actor image %s.', filename, { err }) + + actorImagePathUnsafeCache.del(filename) + + image.onDisk = false + image.save() + .catch(err => logger.error('Cannot save new actor image disk state.', { err })) + } + + return next(err) + }) } async function getPreview (req: express.Request, res: express.Response) { const result = await VideosPreviewCache.Instance.getFilePath(req.params.filename) - if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + if (!result) return res.status(HttpStatusCode.NOT_FOUND_404).end() 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(req.params.filename) - if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404) + if (!result) return res.status(HttpStatusCode.NOT_FOUND_404).end() 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) + if (!result) return res.status(HttpStatusCode.NOT_FOUND_404).end() // Torrents still use the old naming convention (video uuid + .torrent) return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.SERVER })