Tente usar o ulaw em vez de wav & recode-lo mais tarde, também passando caller-id como um argumento pode não funcionar de forma confiável, então eu costumo passá-lo como uma extensão de plano de discagem em vez disso. Tente isto para ver se funciona (pode ser necessário instalar sox
):
exten => 8916XXXXXXX,1,NoOp()
exten => 8916XXXXXXX,n,Verbose("Writing call")
exten => 8916XXXXXXX,n,Gosub(record_out,${EXTEN},1)
exten => 8916XXXXXXX,n,Dial(SIP/sip-trunk/${EXTEN},,T)
exten => 8916XXXXXXX,n,Hangup()
[record_out]
exten => s,1,StopMixMonitor()
exten => s,2,System(sox -q --single-threaded -t ul -r 8000 -c 1 ${CALLFILENAME}.ulaw ${CALLFILENAME}.wav && rm ${CALLFILENAME}.ulaw)
exten => _X.,1,Set(MCALLER=${CALLERID(num)})
exten => _X.,n,Set(MCALLED=${MACRO_EXTEN})
exten => _X.,n,Set(MDIRECTION=${IF($["${EXTEN}" = ""]?IN:${EXTEN})})
exten => _X.,n,Set(AUDIOHOOK_INHERIT(MixMonitor)=yes)
exten => _X.,n,Verbose(Call from ${MCALLER} to ${MCALLED} direction ${MDIRECTION})
exten => _X.,n,Set(FOLDER=/mnt/data/${MCALLER})
exten => _X.,n,Set(CALLFILENAME=OUT_${STRFTIME(${EPOCH},,%C%y-%m-%d_%H-%M-%S)}_CID_${MCALLER}_CAID_${MCALLED}_ID${UNIQUEID}_${MDIRECTION})
exten => _X.,n,MixMonitor(${FOLDER}/${CALLFILENAME}.ulaw,a)
exten => _X.,n,Return()