]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - scripts/create-import-video-file-job.ts
Merge branch 'release/2.1.0' into develop
[github/Chocobozzz/PeerTube.git] / scripts / create-import-video-file-job.ts
CommitLineData
2aaa1a3f
C
1import { registerTSPaths } from '../server/helpers/register-ts-paths'
2registerTSPaths()
3
0138af92
FF
4import * as program from 'commander'
5import { resolve } from 'path'
6import { VideoModel } from '../server/models/video/video'
7import { initDatabaseModels } from '../server/initializers'
8import { JobQueue } from '../server/lib/job-queue'
9
10program
11 .option('-v, --video [videoUUID]', 'Video UUID')
12 .option('-i, --import [videoFile]', 'Video file')
13 .description('Import a video file to replace an already uploaded file or to add a new resolution')
14 .parse(process.argv)
15
16if (program['video'] === undefined || program['import'] === undefined) {
17 console.error('All parameters are mandatory.')
18 process.exit(-1)
19}
20
21run()
22 .then(() => process.exit(0))
23 .catch(err => {
24 console.error(err)
25 process.exit(-1)
26 })
27
28async function run () {
29 await initDatabaseModels(true)
30
e2600d8b 31 const video = await VideoModel.loadByUUID(program['video'])
0138af92 32 if (!video) throw new Error('Video not found.')
28be8916 33 if (video.isOwned() === false) throw new Error('Cannot import files of a non owned video.')
0138af92
FF
34
35 const dataInput = {
36 videoUUID: video.uuid,
37 filePath: resolve(program['import'])
38 }
39
40 await JobQueue.Instance.init()
a1587156 41 await JobQueue.Instance.createJobWithPromise({ type: 'video-file-import', payload: dataInput })
0138af92
FF
42 console.log('Import job for video %s created.', video.uuid)
43}