mirror of
https://github.com/Chocobozzz/PeerTube.git
synced 2025-10-03 09:49:20 +02:00
Separate HLS audio and video streams
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
This commit is contained in:
parent
e77ba2dfbc
commit
816f346a60
186 changed files with 5748 additions and 2807 deletions
|
@ -1,4 +1,4 @@
|
|||
import { hasAudioStream } from '@peertube/peertube-ffmpeg'
|
||||
import { VideoFileStream } from '@peertube/peertube-models'
|
||||
import { buildSUUID } from '@peertube/peertube-node-utils'
|
||||
import { AbstractTranscriber, TranscriptionModel, WhisperBuiltinModel, transcriberFactory } from '@peertube/peertube-transcription'
|
||||
import { moveAndProcessCaptionFile } from '@server/helpers/captions-utils.js'
|
||||
|
@ -96,25 +96,30 @@ export async function generateSubtitle (options: {
|
|||
inputFileMutexReleaser = await VideoPathManager.Instance.lockFiles(options.video.uuid)
|
||||
|
||||
const video = await VideoModel.loadFull(options.video.uuid)
|
||||
const file = video.getMaxQualityFile().withVideoOrPlaylist(video)
|
||||
if (!video) {
|
||||
logger.info('Do not process transcription, video does not exist anymore.', lTags(options.video.uuid))
|
||||
return undefined
|
||||
}
|
||||
|
||||
await VideoPathManager.Instance.makeAvailableVideoFile(file, async videoInputPath => {
|
||||
if (await hasAudioStream(videoInputPath) !== true) {
|
||||
logger.info(
|
||||
`Do not run transcription for ${video.uuid} in ${outputPath} because it does not contain an audio stream`,
|
||||
lTags(video.uuid)
|
||||
)
|
||||
const file = video.getMaxQualityFile(VideoFileStream.AUDIO)
|
||||
|
||||
return
|
||||
}
|
||||
if (!file) {
|
||||
logger.info(
|
||||
`Do not run transcription for ${video.uuid} in ${outputPath} because it does not contain an audio stream`,
|
||||
{ video, ...lTags(video.uuid) }
|
||||
)
|
||||
|
||||
return
|
||||
}
|
||||
|
||||
await VideoPathManager.Instance.makeAvailableVideoFile(file, async inputPath => {
|
||||
// Release input file mutex now we are going to run the command
|
||||
setTimeout(() => inputFileMutexReleaser(), 1000)
|
||||
|
||||
logger.info(`Running transcription for ${video.uuid} in ${outputPath}`, lTags(video.uuid))
|
||||
|
||||
const transcriptFile = await transcriber.transcribe({
|
||||
mediaFilePath: videoInputPath,
|
||||
mediaFilePath: inputPath,
|
||||
|
||||
model: CONFIG.VIDEO_TRANSCRIPTION.MODEL_PATH
|
||||
? await TranscriptionModel.fromPath(CONFIG.VIDEO_TRANSCRIPTION.MODEL_PATH)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue