PeerTube/server/controllers/lazy-static.ts

86 lines
2.8 KiB
TypeScript
Raw Normal View History

2019-08-09 04:32:40 -05:00
import * as cors from 'cors'
import * as express from 'express'
import { LAZY_STATIC_PATHS, STATIC_MAX_AGE } from '../initializers/constants'
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 { HttpStatusCode } from '../../shared/core-utils/miscs/http-error-codes'
2019-08-09 04:32:40 -05:00
const lazyStaticRouter = express.Router()
lazyStaticRouter.use(cors())
lazyStaticRouter.use(
LAZY_STATIC_PATHS.AVATARS + ':filename',
asyncMiddleware(getAvatar)
)
lazyStaticRouter.use(
LAZY_STATIC_PATHS.PREVIEWS + ':filename',
2019-08-09 04:32:40 -05:00
asyncMiddleware(getPreview)
)
lazyStaticRouter.use(
2021-02-15 07:08:16 -06:00
LAZY_STATIC_PATHS.VIDEO_CAPTIONS + ':filename',
2019-08-09 04:32:40 -05:00
asyncMiddleware(getVideoCaption)
)
// ---------------------------------------------------------------------------
export {
lazyStaticRouter,
getPreview,
getVideoCaption
}
// ---------------------------------------------------------------------------
async function getAvatar (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 })
}
const avatar = await AvatarModel.loadByName(filename)
if (!avatar) return res.sendStatus(HttpStatusCode.NOT_FOUND_404)
2019-08-09 04:32:40 -05:00
if (avatar.onDisk === false) {
if (!avatar.fileUrl) return res.sendStatus(HttpStatusCode.NOT_FOUND_404)
2019-08-09 04:32:40 -05:00
logger.info('Lazy serve remote avatar image %s.', avatar.fileUrl)
2019-08-09 08:04:36 -05:00
try {
await pushAvatarProcessInQueue({ filename: avatar.filename, fileUrl: avatar.fileUrl })
} catch (err) {
logger.warn('Cannot process remote avatar %s.', avatar.fileUrl, { err })
return res.sendStatus(HttpStatusCode.NOT_FOUND_404)
2019-08-09 08:04:36 -05:00
}
2019-08-09 04:32:40 -05:00
avatar.onDisk = true
avatar.save()
.catch(err => logger.error('Cannot save new avatar disk state.', { err }))
}
const path = avatar.getPath()
avatarPathUnsafeCache.set(filename, path)
return res.sendFile(path, { maxAge: STATIC_MAX_AGE.SERVER })
}
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)
2019-08-09 04:32:40 -05:00
return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.SERVER })
}
async function getVideoCaption (req: express.Request, res: express.Response) {
2021-02-15 07:08:16 -06:00
const result = await VideosCaptionCache.Instance.getFilePath(req.params.filename)
if (!result) return res.sendStatus(HttpStatusCode.NOT_FOUND_404)
2019-08-09 04:32:40 -05:00
return res.sendFile(result.path, { maxAge: STATIC_MAX_AGE.SERVER })
}