[asterisk-bugs] [JIRA] (ASTERISK-27360) Audio file from ffmpeg pops in AGI (but not dialplan)

Naftoli Gugenheim (JIRA) noreply at issues.asterisk.org
Wed Oct 18 19:54:20 CDT 2017


     [ https://issues.asterisk.org/jira/browse/ASTERISK-27360?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel ]

Naftoli Gugenheim updated ASTERISK-27360:
-----------------------------------------

    Description: 
1. Using a custom webapp and recorder.js, I record an audio file. A specimen can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEWjBDTzJxRVh3dHM

2. I run ffmpeg -i /tmp/upload7121127648236719621.wav -ac 1 -ar 8000 -y /tmp/test1.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEckJKZWxtRHJ6RUU

3. I run sox /tmp/test1.wav /tmp/test.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEYmNIbkNOaDhwMjA

The Problem:

The file from step 2 plays fine using Playback and Background in the dialplan. However when using the AGI command STREAM FILE, there is a terrible popping sound at the beginning.

Here is what it sounds like listening to test1 repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEZzFLczdQaXNYVTg

Here is what it sounds like listening to test repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEWk9KZFgxNkc5WXc

The testing was done with this AGI script (changing the filename as needed):

{code:bash}
#!/bin/bash


checkresults() {
	while read line
	do
	case ${line:0:4} in
	"200 " ) echo $line >&2
	         return;;
	"510 " ) echo $line >&2
	         return;;	
	"520 " ) echo $line >&2
	         return;;
	*      ) echo $line >&2;;	#keep on reading those Invlid command
					#command syntax until "520 End ..."
	esac
	done
}


declare -a array
while read -e ARG && [ "$ARG" ] ; do
	array=(` echo $ARG | sed -e 's/://'`)
	export ${array[0]}=${array[1]}
done


# following variables are available from asterisk 
echo $agi_request >&2
echo $agi_channel >&2
echo $agi_language >&2
echo $agi_type >&2
echo $agi_uniqueid >&2
echo $agi_callerid >&2
echo $agi_dnid >&2
echo $agi_rdnis >&2
echo $agi_context >&2
echo $agi_extension >&2
echo $agi_priority >&2
echo $agi_enhanced >&2


echo 'ANSWER'

checkresults

while true; do
	sleep 1
	echo begin >&2
	echo 'STREAM FILE /tmp/test ""'
	echo end >&2
	sleep 1 
	checkresults
done
{code}


  was:
1. Using a custom webapp and recorder.js, I record an audio file. A specimen can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEWjBDTzJxRVh3dHM

2. I run ffmpeg -i /tmp/upload7121127648236719621.wav -ac 1 -ar 8000 -y /tmp/test1.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEckJKZWxtRHJ6RUU

3. I run sox /tmp/test1.wav /tmp/test.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEYmNIbkNOaDhwMjA

The Problem:

The file from step 2 plays fine using Playback and Background in the dialplan. However when using the AGI command STREAM FILE, there is a terrible popping sound at the beginning.

Here is what it sounds like listening to test1 repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEZzFLczdQaXNYVTg

Here is what it sounds like listening to test repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEWk9KZFgxNkc5WXc

The testing was done with this AGI script (changing the filename as needed):

#!/bin/bash


checkresults() {
	while read line
	do
	case ${line:0:4} in
	"200 " ) echo $line >&2
	         return;;
	"510 " ) echo $line >&2
	         return;;	
	"520 " ) echo $line >&2
	         return;;
	*      ) echo $line >&2;;	#keep on reading those Invlid command
					#command syntax until "520 End ..."
	esac
	done
}


declare -a array
while read -e ARG && [ "$ARG" ] ; do
	array=(` echo $ARG | sed -e 's/://'`)
	export ${array[0]}=${array[1]}
done


# following variables are available from asterisk 
echo $agi_request >&2
echo $agi_channel >&2
echo $agi_language >&2
echo $agi_type >&2
echo $agi_uniqueid >&2
echo $agi_callerid >&2
echo $agi_dnid >&2
echo $agi_rdnis >&2
echo $agi_context >&2
echo $agi_extension >&2
echo $agi_priority >&2
echo $agi_enhanced >&2


echo 'ANSWER'

checkresults

while true; do
	sleep 1
	echo begin >&2
	echo 'STREAM FILE /tmp/test ""'
	echo end >&2
	sleep 1 
	checkresults
done



> Audio file from ffmpeg pops in AGI (but not dialplan)
> -----------------------------------------------------
>
>                 Key: ASTERISK-27360
>                 URL: https://issues.asterisk.org/jira/browse/ASTERISK-27360
>             Project: Asterisk
>          Issue Type: Bug
>      Security Level: None
>    Affects Versions: 13.13.1, 14.3.0
>         Environment: Reproduced in all of:
> * Ubuntu 17.04 official package installed directly on laptop
> * cleardevice/docker-asterisk-latest-pjsip-fail2ban docker image on laptop and on ubuntu 16.04.3
> * cleardevice/docker-cert-asterisk13-ubuntu docker image on laptop and on ubuntu 16.04.3
>            Reporter: Naftoli Gugenheim
>
> 1. Using a custom webapp and recorder.js, I record an audio file. A specimen can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEWjBDTzJxRVh3dHM
> 2. I run ffmpeg -i /tmp/upload7121127648236719621.wav -ac 1 -ar 8000 -y /tmp/test1.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEckJKZWxtRHJ6RUU
> 3. I run sox /tmp/test1.wav /tmp/test.wav. The result can be accessed here: https://drive.google.com/open?id=0B2SmgnDyV1aEYmNIbkNOaDhwMjA
> The Problem:
> The file from step 2 plays fine using Playback and Background in the dialplan. However when using the AGI command STREAM FILE, there is a terrible popping sound at the beginning.
> Here is what it sounds like listening to test1 repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEZzFLczdQaXNYVTg
> Here is what it sounds like listening to test repeated: https://drive.google.com/open?id=0B2SmgnDyV1aEWk9KZFgxNkc5WXc
> The testing was done with this AGI script (changing the filename as needed):
> {code:bash}
> #!/bin/bash
> checkresults() {
> 	while read line
> 	do
> 	case ${line:0:4} in
> 	"200 " ) echo $line >&2
> 	         return;;
> 	"510 " ) echo $line >&2
> 	         return;;	
> 	"520 " ) echo $line >&2
> 	         return;;
> 	*      ) echo $line >&2;;	#keep on reading those Invlid command
> 					#command syntax until "520 End ..."
> 	esac
> 	done
> }
> declare -a array
> while read -e ARG && [ "$ARG" ] ; do
> 	array=(` echo $ARG | sed -e 's/://'`)
> 	export ${array[0]}=${array[1]}
> done
> # following variables are available from asterisk 
> echo $agi_request >&2
> echo $agi_channel >&2
> echo $agi_language >&2
> echo $agi_type >&2
> echo $agi_uniqueid >&2
> echo $agi_callerid >&2
> echo $agi_dnid >&2
> echo $agi_rdnis >&2
> echo $agi_context >&2
> echo $agi_extension >&2
> echo $agi_priority >&2
> echo $agi_enhanced >&2
> echo 'ANSWER'
> checkresults
> while true; do
> 	sleep 1
> 	echo begin >&2
> 	echo 'STREAM FILE /tmp/test ""'
> 	echo end >&2
> 	sleep 1 
> 	checkresults
> done
> {code}



--
This message was sent by Atlassian JIRA
(v6.2#6252)



More information about the asterisk-bugs mailing list