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
106 lines
2.9 KiB
TypeScript
106 lines
2.9 KiB
TypeScript
import { Injectable } from '@angular/core'
|
|
import { FormGroup } from '@angular/forms'
|
|
import { formatICU } from '@app/helpers'
|
|
|
|
export type ResolutionOption = {
|
|
id: string
|
|
label: string
|
|
description?: string
|
|
}
|
|
|
|
@Injectable()
|
|
export class EditConfigurationService {
|
|
|
|
getTranscodingResolutions () {
|
|
return [
|
|
{
|
|
id: '0p',
|
|
label: $localize`Audio-only`,
|
|
// eslint-disable-next-line max-len
|
|
description: $localize`"Split audio and video" must be enabled for the PeerTube player to propose an "Audio only" resolution to users`
|
|
},
|
|
{
|
|
id: '144p',
|
|
label: $localize`144p`
|
|
},
|
|
{
|
|
id: '240p',
|
|
label: $localize`240p`
|
|
},
|
|
{
|
|
id: '360p',
|
|
label: $localize`360p`
|
|
},
|
|
{
|
|
id: '480p',
|
|
label: $localize`480p`
|
|
},
|
|
{
|
|
id: '720p',
|
|
label: $localize`720p`
|
|
},
|
|
{
|
|
id: '1080p',
|
|
label: $localize`1080p`
|
|
},
|
|
{
|
|
id: '1440p',
|
|
label: $localize`1440p`
|
|
},
|
|
{
|
|
id: '2160p',
|
|
label: $localize`2160p`
|
|
}
|
|
]
|
|
}
|
|
|
|
isTranscodingEnabled (form: FormGroup) {
|
|
return form.value['transcoding']['enabled'] === true
|
|
}
|
|
|
|
isHLSEnabled (form: FormGroup) {
|
|
return form.value['transcoding']['hls']['enabled'] === true
|
|
}
|
|
|
|
isRemoteRunnerVODEnabled (form: FormGroup) {
|
|
return form.value['transcoding']['remoteRunners']['enabled'] === true
|
|
}
|
|
|
|
isRemoteRunnerLiveEnabled (form: FormGroup) {
|
|
return form.value['live']['transcoding']['remoteRunners']['enabled'] === true
|
|
}
|
|
|
|
isStudioEnabled (form: FormGroup) {
|
|
return form.value['videoStudio']['enabled'] === true
|
|
}
|
|
|
|
isLiveEnabled (form: FormGroup) {
|
|
return form.value['live']['enabled'] === true
|
|
}
|
|
|
|
isLiveTranscodingEnabled (form: FormGroup) {
|
|
return form.value['live']['transcoding']['enabled'] === true
|
|
}
|
|
|
|
getTotalTranscodingThreads (form: FormGroup) {
|
|
const transcodingEnabled = form.value['transcoding']['enabled']
|
|
const transcodingThreads = form.value['transcoding']['threads']
|
|
const liveTranscodingEnabled = form.value['live']['transcoding']['enabled']
|
|
const liveTranscodingThreads = form.value['live']['transcoding']['threads']
|
|
|
|
// checks whether all enabled method are on fixed values and not on auto (= 0)
|
|
let noneOnAuto = !transcodingEnabled || +transcodingThreads > 0
|
|
noneOnAuto &&= !liveTranscodingEnabled || +liveTranscodingThreads > 0
|
|
|
|
// count total of fixed value, repalcing auto by a single thread (knowing it will display "at least")
|
|
let value = 0
|
|
if (transcodingEnabled) value += +transcodingThreads || 1
|
|
if (liveTranscodingEnabled) value += +liveTranscodingThreads || 1
|
|
|
|
return {
|
|
value,
|
|
atMost: noneOnAuto, // auto switches everything to a least estimation since ffmpeg will take as many threads as possible
|
|
unit: formatICU($localize`{value, plural, =1 {thread} other {threads}}`, { value })
|
|
}
|
|
}
|
|
}
|