1 import { registerTSPaths } from '../server/helpers/register-ts-paths'
4 import { program } from 'commander'
5 import { VideoModel } from '@server/models/video/video'
6 import { initDatabaseModels } from '@server/initializers/database'
7 import { VideoStorage } from '@shared/models'
8 import { moveToExternalStorageState } from '@server/lib/video-state'
9 import { JobQueue } from '@server/lib/job-queue'
10 import { CONFIG } from '@server/initializers/config'
13 .description('Move videos to another storage.')
14 .option('-o, --to-object-storage', 'Move videos in object storage')
15 .option('-v, --video [videoUUID]', 'Move a specific video')
16 .option('-a, --all-videos', 'Migrate all videos')
19 const options = program.opts()
21 if (!options['toObjectStorage']) {
22 console.error('You need to choose where to send video files.')
26 if (!options['video'] && !options['allVideos']) {
27 console.error('You need to choose which videos to move.')
31 if (options['toObjectStorage'] && !CONFIG.OBJECT_STORAGE.ENABLED) {
32 console.error('Object storage is not enabled on this instance.')
37 .then(() => process.exit(0))
38 .catch(err => console.error(err))
40 async function run () {
41 await initDatabaseModels(true)
43 JobQueue.Instance.init(true)
45 let ids: number[] = []
47 if (options['video']) {
48 const video = await VideoModel.load(options['video'])
51 console.error('Unknown video ' + options['video'])
55 if (video.remote === true) {
56 console.error('Cannot process a remote video')
62 ids = await VideoModel.listLocalIds()
65 for (const id of ids) {
66 const videoFull = await VideoModel.loadAndPopulateAccountAndServerAndTags(id)
68 const files = videoFull.VideoFiles || []
69 const hls = videoFull.getHLSPlaylist()
71 if (files.some(f => f.storage === VideoStorage.FILE_SYSTEM) || hls?.storage === VideoStorage.FILE_SYSTEM) {
72 console.log('Processing video %s.', videoFull.name)
74 const success = await moveToExternalStorageState(videoFull, false, undefined)
78 'Cannot create move job for %s: job creation may have failed or there may be pending transcoding jobs for this video',
84 console.log(`Created move-to-object-storage job for ${videoFull.name}.`)