fix(stream): downmix estéreo en el audio re-encodeado del modo copy

Sin -ac 2 una fuente 5.1 (AC3/EAC3) producía AAC de 6 canales del encoder
nativo de ffmpeg, que WebKit/Apple HLS rechaza al sniffar el primer
segmento: en el access log de Safari se ve master → index → init → seg-0
dos veces y silencio. Era el discriminador exacto del patrón de campo:
episodios con AAC estéreo (copy de audio) reproducían en iPhone; todas las
películas 5.1 fallaban. Verificado con Safari/macOS via WebDriver-less
access log: con -ac 2 la progresión de segmentos avanza con normalidad.

Espeja los flags del path de encode (aac 192k 48kHz estéreo). Test smoke
ampliado: el re-encode debe llevar -ac 2.
This commit is contained in:
Deivid Soto 2026-06-11 00:02:53 +02:00
parent 6c756a2569
commit f89396ceed
3 changed files with 20 additions and 1 deletions

View file

@ -1968,7 +1968,12 @@ func buildHLSCopyArgs(cfg HLSSessionConfig, probe *StreamProbe, tmpDir string) [
if strings.EqualFold(audioCodec, "aac") {
args = append(args, "-c:a", "copy")
} else {
args = append(args, "-c:a", "aac", "-b:a", "192k")
// Mirror the encode path exactly: AAC stereo 48k. WITHOUT -ac 2 a 5.1
// source produces 6-channel ffmpeg-native AAC, which WebKit/Apple HLS
// rejects at the first media segment (observed via Safari access log:
// master → index → init → seg-0 fetched twice, then silence — every
// 5.1 movie failed on iPhone while stereo-AAC episodes played).
args = append(args, "-c:a", "aac", "-b:a", "192k", "-ar", "48000", "-ac", "2")
}
args = append(args,