mirror of https://github.com/Chocobozzz/PeerTube
Optimize remote thumbnail processing
parent
a35a22797c
commit
374b725df5
|
@ -1,5 +1,6 @@
|
|||
import chaiJsonSchema = require('chai-json-schema')
|
||||
import { copy, move } from 'fs-extra'
|
||||
import { join } from 'path'
|
||||
|
||||
import { ThumbnailType } from '../../shared/models/videos/thumbnail.type'
|
||||
import { generateImageFromVideoFile } from '../helpers/ffmpeg-utils'
|
||||
import { processImage } from '../helpers/image-utils'
|
||||
|
@ -69,7 +70,19 @@ function createVideoMiniatureFromUrl (options: {
|
|||
? null
|
||||
: downloadUrl
|
||||
|
||||
const thumbnailCreator = () => downloadImage(downloadUrl, basePath, filename, { width, height })
|
||||
// If the thumbnail URL did not change
|
||||
const existingUrl = existingThumbnail
|
||||
? existingThumbnail.fileUrl
|
||||
: null
|
||||
|
||||
// If the thumbnail URL did not change and has a unique filename (introduced in 3.2), avoid thumbnail processing
|
||||
const thumbnailUrlChanged = !existingUrl || existingUrl !== downloadUrl || downloadUrl.endsWith(`${video.uuid}.jpg`)
|
||||
const thumbnailCreator = () => {
|
||||
if (thumbnailUrlChanged) return downloadImage(downloadUrl, basePath, filename, { width, height })
|
||||
|
||||
return copy(existingThumbnail.getPath(), ThumbnailModel.buildPath(type, filename))
|
||||
}
|
||||
|
||||
return createThumbnailFromFunction({ thumbnailCreator, filename, height, width, type, existingThumbnail, fileUrl })
|
||||
}
|
||||
|
||||
|
|
|
@ -158,6 +158,12 @@ export class ThumbnailModel extends Model {
|
|||
return ThumbnailModel.findOne(query)
|
||||
}
|
||||
|
||||
static buildPath (type: ThumbnailType, filename: string) {
|
||||
const directory = ThumbnailModel.types[type].directory
|
||||
|
||||
return join(directory, filename)
|
||||
}
|
||||
|
||||
getFileUrl (video: MVideoAccountLight) {
|
||||
const staticPath = ThumbnailModel.types[this.type].staticPath + this.filename
|
||||
|
||||
|
@ -169,13 +175,11 @@ export class ThumbnailModel extends Model {
|
|||
}
|
||||
|
||||
getPath () {
|
||||
const directory = ThumbnailModel.types[this.type].directory
|
||||
return join(directory, this.filename)
|
||||
return ThumbnailModel.buildPath(this.type, this.filename)
|
||||
}
|
||||
|
||||
getPreviousPath () {
|
||||
const directory = ThumbnailModel.types[this.type].directory
|
||||
return join(directory, this.previousThumbnailFilename)
|
||||
return ThumbnailModel.buildPath(this.type, this.previousThumbnailFilename)
|
||||
}
|
||||
|
||||
removeThumbnail () {
|
||||
|
|
Loading…
Reference in New Issue