mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-04 02:09:37 +02:00

Allows: * The HLS player to propose an "Audio only" resolution * The live to output an "Audio only" resolution * The live to ingest and output an "Audio only" stream This feature is under a config for VOD videos and is enabled by default for lives In the future we can imagine: * To propose multiple audio streams for a specific video * To ingest an audio only VOD and just output an audio only "video" (the player would play the audio file and PeerTube would not generate additional resolutions) This commit introduce a new way to download videos: * Add "/download/videos/generate/:videoId" endpoint where PeerTube can mux an audio only and a video only file to a mp4 container * The download client modal introduces a new default panel where the user can choose resolutions it wants to download
48 lines
1.7 KiB
TypeScript
48 lines
1.7 KiB
TypeScript
import { pick } from '@peertube/peertube-core-utils'
|
|
import { TranscodingJobBuilderPayload, VideoFileStream } from '@peertube/peertube-models'
|
|
import { createOptimizeOrMergeAudioJobs } from '@server/lib/transcoding/create-transcoding-job.js'
|
|
import { UserModel } from '@server/models/user/user.js'
|
|
import { VideoJobInfoModel } from '@server/models/video/video-job-info.js'
|
|
import { VideoModel } from '@server/models/video/video.js'
|
|
import { Job } from 'bullmq'
|
|
import { logger } from '../../../helpers/logger.js'
|
|
import { JobQueue } from '../job-queue.js'
|
|
|
|
async function processTranscodingJobBuilder (job: Job) {
|
|
const payload = job.data as TranscodingJobBuilderPayload
|
|
|
|
logger.info('Processing transcoding job builder in job %s.', job.id)
|
|
|
|
if (payload.optimizeJob) {
|
|
const video = await VideoModel.loadFull(payload.videoUUID)
|
|
const user = await UserModel.loadByVideoId(video.id)
|
|
const videoFile = video.getMaxQualityFile(VideoFileStream.VIDEO) || video.getMaxQualityFile(VideoFileStream.AUDIO)
|
|
|
|
await createOptimizeOrMergeAudioJobs({
|
|
...pick(payload.optimizeJob, [ 'isNewVideo' ]),
|
|
|
|
video,
|
|
videoFile,
|
|
user,
|
|
videoFileAlreadyLocked: false
|
|
})
|
|
}
|
|
|
|
for (const job of (payload.jobs || [])) {
|
|
await JobQueue.Instance.createJob(job)
|
|
|
|
await VideoJobInfoModel.increaseOrCreate(payload.videoUUID, 'pendingTranscode')
|
|
}
|
|
|
|
for (const sequentialJobs of (payload.sequentialJobs || [])) {
|
|
await JobQueue.Instance.createSequentialJobFlow(...sequentialJobs)
|
|
|
|
await VideoJobInfoModel.increaseOrCreate(payload.videoUUID, 'pendingTranscode', sequentialJobs.filter(s => !!s).length)
|
|
}
|
|
}
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
export {
|
|
processTranscodingJobBuilder
|
|
}
|