1
0
Fork 0
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:
Mert 2024-02-21 00:25:30 -05:00 committed by GitHub
parent 7c34d0595e
commit 397570ad1a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
5 changed files with 50 additions and 43 deletions

View file

@ -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',

View file

@ -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,

View file

@ -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],

View file

@ -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;

View file

@ -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