mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-03 09:49:20 +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
61 lines
2.2 KiB
TypeScript
61 lines
2.2 KiB
TypeScript
import { HttpStatusCode, UserRight, VideoState, VideoTranscodingCreate } from '@peertube/peertube-models'
|
|
import { logger, loggerTagsFactory } from '@server/helpers/logger.js'
|
|
import { Hooks } from '@server/lib/plugins/hooks.js'
|
|
import { createTranscodingJobs } from '@server/lib/transcoding/create-transcoding-job.js'
|
|
import { computeResolutionsToTranscode } from '@server/lib/transcoding/transcoding-resolutions.js'
|
|
import { VideoJobInfoModel } from '@server/models/video/video-job-info.js'
|
|
import express from 'express'
|
|
import { asyncMiddleware, authenticate, createTranscodingValidator, ensureUserHasRight } from '../../../middlewares/index.js'
|
|
|
|
const lTags = loggerTagsFactory('api', 'video')
|
|
const transcodingRouter = express.Router()
|
|
|
|
transcodingRouter.post('/:videoId/transcoding',
|
|
authenticate,
|
|
ensureUserHasRight(UserRight.RUN_VIDEO_TRANSCODING),
|
|
asyncMiddleware(createTranscodingValidator),
|
|
asyncMiddleware(createTranscoding)
|
|
)
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
export {
|
|
transcodingRouter
|
|
}
|
|
|
|
// ---------------------------------------------------------------------------
|
|
|
|
async function createTranscoding (req: express.Request, res: express.Response) {
|
|
const video = res.locals.videoAll
|
|
logger.info('Creating %s transcoding job for %s.', req.body.transcodingType, video.url, lTags())
|
|
|
|
const body: VideoTranscodingCreate = req.body
|
|
|
|
await VideoJobInfoModel.abortAllTasks(video.uuid, 'pendingTranscode')
|
|
|
|
const maxResolution = video.getMaxResolution()
|
|
const hasAudio = video.hasAudio()
|
|
|
|
const resolutions = await Hooks.wrapObject(
|
|
computeResolutionsToTranscode({ input: maxResolution, type: 'vod', includeInput: true, strictLower: false, hasAudio }),
|
|
'filter:transcoding.manual.resolutions-to-transcode.result',
|
|
body
|
|
)
|
|
|
|
if (resolutions.length === 0) {
|
|
return res.sendStatus(HttpStatusCode.NO_CONTENT_204)
|
|
}
|
|
|
|
video.state = VideoState.TO_TRANSCODE
|
|
await video.save()
|
|
|
|
await createTranscodingJobs({
|
|
video,
|
|
resolutions,
|
|
transcodingType: body.transcodingType,
|
|
isNewVideo: false,
|
|
user: null // Don't specify priority since these transcoding jobs are fired by the admin
|
|
})
|
|
|
|
return res.sendStatus(HttpStatusCode.NO_CONTENT_204)
|
|
}
|