aboutsummaryrefslogtreecommitdiffhomepage
path: root/server/lib/files-cache/shared/abstract-permanent-file-cache.ts
diff options
context:
space:
mode:
Diffstat (limited to 'server/lib/files-cache/shared/abstract-permanent-file-cache.ts')
-rw-r--r--server/lib/files-cache/shared/abstract-permanent-file-cache.ts35
1 files changed, 23 insertions, 12 deletions
diff --git a/server/lib/files-cache/shared/abstract-permanent-file-cache.ts b/server/lib/files-cache/shared/abstract-permanent-file-cache.ts
index 297461035..f990e9872 100644
--- a/server/lib/files-cache/shared/abstract-permanent-file-cache.ts
+++ b/server/lib/files-cache/shared/abstract-permanent-file-cache.ts
@@ -1,10 +1,11 @@
1import express from 'express' 1import express from 'express'
2import { LRUCache } from 'lru-cache' 2import { LRUCache } from 'lru-cache'
3import { Model } from 'sequelize'
3import { logger } from '@server/helpers/logger' 4import { logger } from '@server/helpers/logger'
5import { CachePromise } from '@server/helpers/promise-cache'
4import { LRU_CACHE, STATIC_MAX_AGE } from '@server/initializers/constants' 6import { LRU_CACHE, STATIC_MAX_AGE } from '@server/initializers/constants'
5import { downloadImageFromWorker } from '@server/lib/worker/parent-process' 7import { downloadImageFromWorker } from '@server/lib/worker/parent-process'
6import { HttpStatusCode } from '@shared/models' 8import { HttpStatusCode } from '@shared/models'
7import { Model } from 'sequelize'
8 9
9type ImageModel = { 10type ImageModel = {
10 fileUrl: string 11 fileUrl: string
@@ -41,29 +42,39 @@ export abstract class AbstractPermanentFileCache <M extends ImageModel> {
41 return res.sendFile(this.filenameToPathUnsafeCache.get(filename), { maxAge: STATIC_MAX_AGE.SERVER }) 42 return res.sendFile(this.filenameToPathUnsafeCache.get(filename), { maxAge: STATIC_MAX_AGE.SERVER })
42 } 43 }
43 44
44 const image = await this.loadModel(filename) 45 const image = await this.lazyLoadIfNeeded(filename)
45 if (!image) return res.status(HttpStatusCode.NOT_FOUND_404).end() 46 if (!image) return res.status(HttpStatusCode.NOT_FOUND_404).end()
46 47
48 const path = image.getPath()
49 this.filenameToPathUnsafeCache.set(filename, path)
50
51 return res.sendFile(path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }, (err: any) => {
52 if (!err) return
53
54 this.onServeError({ err, image, next, filename })
55 })
56 }
57
58 @CachePromise({
59 keyBuilder: filename => filename
60 })
61 private async lazyLoadIfNeeded (filename: string) {
62 const image = await this.loadModel(filename)
63 if (!image) return undefined
64
47 if (image.onDisk === false) { 65 if (image.onDisk === false) {
48 if (!image.fileUrl) return res.status(HttpStatusCode.NOT_FOUND_404).end() 66 if (!image.fileUrl) return undefined
49 67
50 try { 68 try {
51 await this.downloadRemoteFile(image) 69 await this.downloadRemoteFile(image)
52 } catch (err) { 70 } catch (err) {
53 logger.warn('Cannot process remote image %s.', image.fileUrl, { err }) 71 logger.warn('Cannot process remote image %s.', image.fileUrl, { err })
54 72
55 return res.status(HttpStatusCode.NOT_FOUND_404).end() 73 return undefined
56 } 74 }
57 } 75 }
58 76
59 const path = image.getPath() 77 return image
60 this.filenameToPathUnsafeCache.set(filename, path)
61
62 return res.sendFile(path, { maxAge: STATIC_MAX_AGE.LAZY_SERVER }, (err: any) => {
63 if (!err) return
64
65 this.onServeError({ err, image, next, filename })
66 })
67 } 78 }
68 79
69 async downloadRemoteFile (image: M) { 80 async downloadRemoteFile (image: M) {