mirror of
https://github.com/immich-app/immich.git
synced 2025-01-04 02:46:47 +01:00
chore(server): change transcode default to accept all supported audio codecs (#7283)
* change transcode defaults * don't untick accepted audio codecs * no need to change the transcode policy * fix tests * remove log
This commit is contained in:
parent
7c34d0595e
commit
397570ad1a
5 changed files with 50 additions and 43 deletions
|
@ -1,5 +1,6 @@
|
||||||
import {
|
import {
|
||||||
AssetType,
|
AssetType,
|
||||||
|
AudioCodec,
|
||||||
Colorspace,
|
Colorspace,
|
||||||
ExifEntity,
|
ExifEntity,
|
||||||
SystemConfigKey,
|
SystemConfigKey,
|
||||||
|
@ -475,7 +476,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -542,7 +543,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -571,7 +572,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -629,7 +630,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -706,7 +707,10 @@ describe(MediaService.name, () => {
|
||||||
|
|
||||||
it('should copy video stream when video matches target', async () => {
|
it('should copy video stream when video matches target', async () => {
|
||||||
mediaMock.probe.mockResolvedValue(probeStub.matroskaContainer);
|
mediaMock.probe.mockResolvedValue(probeStub.matroskaContainer);
|
||||||
configMock.load.mockResolvedValue([{ key: SystemConfigKey.FFMPEG_TARGET_VIDEO_CODEC, value: VideoCodec.HEVC }]);
|
configMock.load.mockResolvedValue([
|
||||||
|
{ key: SystemConfigKey.FFMPEG_TARGET_VIDEO_CODEC, value: VideoCodec.HEVC },
|
||||||
|
{ key: SystemConfigKey.FFMPEG_ACCEPTED_AUDIO_CODECS, value: [AudioCodec.AAC] },
|
||||||
|
]);
|
||||||
assetMock.getByIds.mockResolvedValue([assetStub.video]);
|
assetMock.getByIds.mockResolvedValue([assetStub.video]);
|
||||||
await sut.handleVideoConversion({ id: assetStub.video.id });
|
await sut.handleVideoConversion({ id: assetStub.video.id });
|
||||||
expect(mediaMock.transcode).toHaveBeenCalledWith(
|
expect(mediaMock.transcode).toHaveBeenCalledWith(
|
||||||
|
@ -770,7 +774,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -836,7 +840,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -868,7 +872,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -897,7 +901,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -928,7 +932,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v vp9',
|
'-c:v vp9',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -962,7 +966,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v vp9',
|
'-c:v vp9',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -994,7 +998,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v vp9',
|
'-c:v vp9',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1026,7 +1030,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v vp9',
|
'-c:v vp9',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1057,7 +1061,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v vp9',
|
'-c:v vp9',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1087,7 +1091,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1117,7 +1121,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1147,7 +1151,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v hevc',
|
'-c:v hevc',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1181,7 +1185,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v hevc',
|
'-c:v hevc',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1248,7 +1252,7 @@ describe(MediaService.name, () => {
|
||||||
'-rc-lookahead 20',
|
'-rc-lookahead 20',
|
||||||
'-i_qfactor 0.75',
|
'-i_qfactor 0.75',
|
||||||
`-c:v h264_nvenc`,
|
`-c:v h264_nvenc`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1286,7 +1290,7 @@ describe(MediaService.name, () => {
|
||||||
'-rc-lookahead 20',
|
'-rc-lookahead 20',
|
||||||
'-i_qfactor 0.75',
|
'-i_qfactor 0.75',
|
||||||
`-c:v h264_nvenc`,
|
`-c:v h264_nvenc`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1320,7 +1324,7 @@ describe(MediaService.name, () => {
|
||||||
'-rc-lookahead 20',
|
'-rc-lookahead 20',
|
||||||
'-i_qfactor 0.75',
|
'-i_qfactor 0.75',
|
||||||
`-c:v h264_nvenc`,
|
`-c:v h264_nvenc`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1355,7 +1359,7 @@ describe(MediaService.name, () => {
|
||||||
'-rc-lookahead 20',
|
'-rc-lookahead 20',
|
||||||
'-i_qfactor 0.75',
|
'-i_qfactor 0.75',
|
||||||
`-c:v h264_nvenc`,
|
`-c:v h264_nvenc`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1386,7 +1390,7 @@ describe(MediaService.name, () => {
|
||||||
'-rc-lookahead 20',
|
'-rc-lookahead 20',
|
||||||
'-i_qfactor 0.75',
|
'-i_qfactor 0.75',
|
||||||
`-c:v h264_nvenc`,
|
`-c:v h264_nvenc`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1418,7 +1422,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_qsv`,
|
`-c:v h264_qsv`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1455,7 +1459,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device qsv=hw,child_device=/dev/dri/renderD128', '-filter_hw_device hw'],
|
inputOptions: ['-init_hw_device qsv=hw,child_device=/dev/dri/renderD128', '-filter_hw_device hw'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_qsv`,
|
`-c:v h264_qsv`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1491,7 +1495,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_qsv`,
|
`-c:v h264_qsv`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1524,7 +1528,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
inputOptions: ['-init_hw_device qsv=hw', '-filter_hw_device hw'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v vp9_qsv`,
|
`-c:v vp9_qsv`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1568,7 +1572,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1600,7 +1604,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1634,7 +1638,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1664,7 +1668,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/card1', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/card1', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1690,7 +1694,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD129', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD129', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1724,7 +1728,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
inputOptions: ['-init_hw_device vaapi=accel:/dev/dri/renderD128', '-filter_hw_device accel'],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_vaapi`,
|
`-c:v h264_vaapi`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1757,7 +1761,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1798,7 +1802,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v hevc_rkmpp_encoder`,
|
`-c:v hevc_rkmpp_encoder`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1838,7 +1842,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
`-c:v h264_rkmpp_encoder`,
|
`-c:v h264_rkmpp_encoder`,
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1872,7 +1876,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1899,7 +1903,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
@ -1926,7 +1930,7 @@ describe(MediaService.name, () => {
|
||||||
inputOptions: [],
|
inputOptions: [],
|
||||||
outputOptions: [
|
outputOptions: [
|
||||||
'-c:v h264',
|
'-c:v h264',
|
||||||
'-c:a aac',
|
'-c:a copy',
|
||||||
'-movflags faststart',
|
'-movflags faststart',
|
||||||
'-fps_mode passthrough',
|
'-fps_mode passthrough',
|
||||||
'-map 0:0',
|
'-map 0:0',
|
||||||
|
|
|
@ -33,7 +33,7 @@ export const defaults = Object.freeze<SystemConfig>({
|
||||||
targetVideoCodec: VideoCodec.H264,
|
targetVideoCodec: VideoCodec.H264,
|
||||||
acceptedVideoCodecs: [VideoCodec.H264],
|
acceptedVideoCodecs: [VideoCodec.H264],
|
||||||
targetAudioCodec: AudioCodec.AAC,
|
targetAudioCodec: AudioCodec.AAC,
|
||||||
acceptedAudioCodecs: [AudioCodec.AAC],
|
acceptedAudioCodecs: [AudioCodec.AAC, AudioCodec.MP3, AudioCodec.LIBOPUS],
|
||||||
targetResolution: '720',
|
targetResolution: '720',
|
||||||
maxBitrate: '0',
|
maxBitrate: '0',
|
||||||
bframes: -1,
|
bframes: -1,
|
||||||
|
|
|
@ -43,7 +43,7 @@ const updatedConfig = Object.freeze<SystemConfig>({
|
||||||
threads: 0,
|
threads: 0,
|
||||||
preset: 'ultrafast',
|
preset: 'ultrafast',
|
||||||
targetAudioCodec: AudioCodec.AAC,
|
targetAudioCodec: AudioCodec.AAC,
|
||||||
acceptedAudioCodecs: [AudioCodec.AAC],
|
acceptedAudioCodecs: [AudioCodec.AAC, AudioCodec.MP3, AudioCodec.LIBOPUS],
|
||||||
targetResolution: '720',
|
targetResolution: '720',
|
||||||
targetVideoCodec: VideoCodec.H264,
|
targetVideoCodec: VideoCodec.H264,
|
||||||
acceptedVideoCodecs: [VideoCodec.H264],
|
acceptedVideoCodecs: [VideoCodec.H264],
|
||||||
|
|
|
@ -7,7 +7,7 @@ export class SystemConfigEntity<T = SystemConfigValue> {
|
||||||
key!: SystemConfigKey;
|
key!: SystemConfigKey;
|
||||||
|
|
||||||
@Column({ type: 'varchar', nullable: true, transformer: { to: JSON.stringify, from: JSON.parse } })
|
@Column({ type: 'varchar', nullable: true, transformer: { to: JSON.stringify, from: JSON.parse } })
|
||||||
value!: T;
|
value!: T | T[];
|
||||||
}
|
}
|
||||||
|
|
||||||
export type SystemConfigValue = string | number | boolean;
|
export type SystemConfigValue = string | number | boolean;
|
||||||
|
|
|
@ -90,7 +90,10 @@
|
||||||
]}
|
]}
|
||||||
name="acodec"
|
name="acodec"
|
||||||
isEdited={config.ffmpeg.targetAudioCodec !== savedConfig.ffmpeg.targetAudioCodec}
|
isEdited={config.ffmpeg.targetAudioCodec !== savedConfig.ffmpeg.targetAudioCodec}
|
||||||
on:select={() => (config.ffmpeg.acceptedAudioCodecs = [config.ffmpeg.targetAudioCodec])}
|
on:select={() =>
|
||||||
|
config.ffmpeg.acceptedAudioCodecs.includes(config.ffmpeg.targetAudioCodec)
|
||||||
|
? null
|
||||||
|
: config.ffmpeg.acceptedAudioCodecs.push(config.ffmpeg.targetAudioCodec)}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<SettingCheckboxes
|
<SettingCheckboxes
|
||||||
|
|
Loading…
Reference in a new issue