import * as asyncLRU from 'async-lru'
import { createWriteStream } from 'fs'
import { join } from 'path'
-import { logger, unlinkPromise } from '../../helpers'
+import { unlinkPromise } from '../../helpers/core-utils'
+import { logger } from '../../helpers/logger'
import { CACHE, CONFIG } from '../../initializers'
import { VideoModel } from '../../models/video/video'
import { fetchRemoteVideoPreview } from '../activitypub'
})
}
- getPreviewPath (key: string) {
+ async getPreviewPath (key: string) {
+ const video = await VideoModel.loadByUUID(key)
+ if (!video) return undefined
+
+ if (video.isOwned()) return join(CONFIG.STORAGE.PREVIEWS_DIR, video.getPreviewName())
+
return new Promise<string>((res, rej) => {
this.lru.get(key, (err, value) => {
err ? rej(err) : res(value)
const video = await VideoModel.loadByUUIDAndPopulateAccountAndServerAndTags(key)
if (!video) return undefined
- if (video.isOwned()) return join(CONFIG.STORAGE.PREVIEWS_DIR, video.getPreviewName())
-
- const res = await this.saveRemotePreviewAndReturnPath(video)
+ if (video.isOwned()) throw new Error('Cannot load preview of owned video.')
- return res
+ return this.saveRemotePreviewAndReturnPath(video)
}
private saveRemotePreviewAndReturnPath (video: VideoModel) {
- const req = fetchRemoteVideoPreview(video)
-
return new Promise<string>((res, rej) => {
+ const req = fetchRemoteVideoPreview(video, rej)
const path = join(CACHE.DIRECTORIES.PREVIEWS, video.getPreviewName())
const stream = createWriteStream(path)
req.pipe(stream)
- .on('finish', () => res(path))
- .on('error', (err) => rej(err))
+ .on('error', (err) => rej(err))
+ .on('finish', () => res(path))
})
}
}