]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/commitdiff
Fix create transcoding job script
authorChocobozzz <me@florianbigard.com>
Thu, 11 Feb 2021 14:40:54 +0000 (15:40 +0100)
committerChocobozzz <me@florianbigard.com>
Thu, 11 Feb 2021 14:40:54 +0000 (15:40 +0100)
Depending on the file and the webtorrent/hls config

scripts/create-transcoding-job.ts

index 5f56d6d3684039e7be7e65c6691ac3670918e423..9f1d8b956939c738ab214c8e464e05a9950cf416 100755 (executable)
@@ -7,6 +7,7 @@ import { initDatabaseModels } from '../server/initializers/database'
 import { JobQueue } from '../server/lib/job-queue'
 import { computeResolutionsToTranscode } from '@server/helpers/ffprobe-utils'
 import { VideoTranscodingPayload } from '@shared/models'
+import { CONFIG } from '@server/initializers/config'
 
 program
   .option('-v, --video [videoUUID]', 'Video UUID')
@@ -42,7 +43,8 @@ async function run () {
   const dataInput: VideoTranscodingPayload[] = []
   const { videoFileResolution } = await video.getMaxQualityResolution()
 
-  if (options.generateHls) {
+  // Generate HLS files
+  if (options.generateHls || CONFIG.TRANSCODING.WEBTORRENT.ENABLED === false) {
     const resolutionsEnabled = options.resolution
       ? [ options.resolution ]
       : computeResolutionsToTranscode(videoFileResolution, 'vod').concat([ videoFileResolution ])
@@ -57,19 +59,26 @@ async function run () {
         isMaxQuality: false
       })
     }
-  } else if (options.resolution !== undefined) {
-    dataInput.push({
-      type: 'new-resolution-to-webtorrent',
-      videoUUID: video.uuid,
-      isNewVideo: false,
-      resolution: options.resolution
-    })
   } else {
-    dataInput.push({
-      type: 'optimize-to-webtorrent',
-      videoUUID: video.uuid,
-      isNewVideo: false
-    })
+    if (options.resolution !== undefined) {
+      dataInput.push({
+        type: 'new-resolution-to-webtorrent',
+        videoUUID: video.uuid,
+        isNewVideo: false,
+        resolution: options.resolution
+      })
+    } else {
+      if (video.VideoFiles.length === 0) {
+        console.error('Cannot regenerate webtorrent files with a HLS only video.')
+        return
+      }
+
+      dataInput.push({
+        type: 'optimize-to-webtorrent',
+        videoUUID: video.uuid,
+        isNewVideo: false
+      })
+    }
   }
 
   await JobQueue.Instance.init()