-import { registerTSPaths } from '../server/helpers/register-ts-paths'
-registerTSPaths()
-
-import * as Bluebird from 'bluebird'
-import * as program from 'commander'
-import { pathExists } from 'fs-extra'
-import { processImage } from '@server/helpers/image-utils'
+import { map } from 'bluebird'
+import { program } from 'commander'
+import { pathExists, remove } from 'fs-extra'
+import { generateImageFilename, processImage } from '@server/helpers/image-utils'
import { THUMBNAILS_SIZE } from '@server/initializers/constants'
-import { VideoModel } from '@server/models/video/video'
-import { MVideo } from '@server/types/models'
import { initDatabaseModels } from '@server/initializers/database'
+import { VideoModel } from '@server/models/video/video'
program
.description('Regenerate local thumbnails using preview files')
async function run () {
await initDatabaseModels(true)
- const videos = await VideoModel.listLocal()
+ const ids = await VideoModel.listLocalIds()
- await Bluebird.map(videos, v => {
- return processVideo(v)
- .catch(err => console.error('Cannot process video %s.', v.url, err))
+ await map(ids, id => {
+ return processVideo(id)
+ .catch(err => console.error('Cannot process video %d.', id, err))
}, { concurrency: 20 })
}
-async function processVideo (videoArg: MVideo) {
- const video = await VideoModel.loadWithFiles(videoArg.id)
+async function processVideo (id: number) {
+ const video = await VideoModel.loadWithFiles(id)
console.log('Processing video %s.', video.name)
const thumbnail = video.getMiniature()
const preview = video.getPreview()
- const thumbnailPath = thumbnail.getPath()
const previewPath = preview.getPath()
- if (!await pathExists(thumbnailPath)) {
- throw new Error(`Thumbnail ${thumbnailPath} does not exist on disk`)
- }
-
if (!await pathExists(previewPath)) {
throw new Error(`Preview ${previewPath} does not exist on disk`)
}
width: THUMBNAILS_SIZE.width,
height: THUMBNAILS_SIZE.height
}
+
+ const oldPath = thumbnail.getPath()
+
+ // Update thumbnail
+ thumbnail.filename = generateImageFilename()
+ thumbnail.width = size.width
+ thumbnail.height = size.height
+
+ const thumbnailPath = thumbnail.getPath()
await processImage(previewPath, thumbnailPath, size, true)
+
+ // Save new attributes
+ await thumbnail.save()
+
+ // Remove old thumbnail
+ await remove(oldPath)
+
+ // Don't federate, remote instances will refresh the thumbnails after a while
}