Я проектирую диалплан, как показано ниже. Все работает нормально, но расширение таймаута не работает.
autofallthrough=no
прокомментирован в файле extension.conf.Расширение таймаута не работает в звездочке 11
subContinueOrNot - это подпрограмма, вызванная контекстом с именем «study4». dialplan ждет 10 секунд после воспроизведения файлов «notCallPress2», а затем возвращает пустое значение. Недопустимое расширение работает нормально. Но это не будет длительным продлением.
[subContinueOrNot]
exten=>s,1,Playback(study4/okCallPress1)
exten=>s,n,Playback(study4/notCallPress2)
exten=>s,n,Set(PARAM=)
exten=>s,n,WaitExten(10)
exten=>s,n(ret),Return(${PARAM})
exten=>1,1,Set(PARAM=1)
exten=>1,n,Goto(s,ret)
exten=>2,1,Set(PARAM=2)
exten=>2,n,Goto(s,ret)
exten=>i,1,GoSub(subInvalid,s,1(${INVALID_EXTEN}))
exten=>i,n,Set(PARAM=${GOSUB_RETVAL})
exten=>i,n,Goto(s,ret)
exten=>t,1,GoSub(subTimeout,s,1())
exten=>t,n,Set(PARAM=timeOut)
exten=>t,n,Goto(s,ret)
exten=>h,1,Goto(study4,h,1,)
Ниже приведен вывод на консоли звездочки.
-- <SIP/101-0000000f> Playing 'study4/weAsk.slin' (language 'en')
-- Executing [[email protected]:10] Gosub("SIP/101-0000000f", "subContinueOrNot,s,1()") in new stack
-- Executing [[email protected]:1] Playback("SIP/101-0000000f", "study4/okCallPress1") in new stack
-- <SIP/101-0000000f> Playing 'study4/okCallPress1.slin' (language 'en')
-- Executing [[email protected]:2] Playback("SIP/101-0000000f", "study4/notCallPress2") in new stack
-- <SIP/101-0000000f> Playing 'study4/notCallPress2.slin' (language 'en')
-- Executing [[email protected]:3] Set("SIP/101-0000000f", "PARAM=") in new stack
-- Executing [[email protected]:4] WaitExten("SIP/101-0000000f", "10") in new stack
-- Timeout on SIP/101-0000000f, continuing...
-- Executing [[email protected]:5] Return("SIP/101-0000000f", "") in new stack
-- Executing [[email protected]:11] Set("SIP/101-0000000f", "RV=") in new stack
-- Executing [[email protected]:12] GotoIf("SIP/101-0000000f", "0?s,cont1:s,stop1") in new stack
-- Goto (study4,s,13)
-- Executing [[email protected]:13] Playback("SIP/101-0000000f", "study4/callAgain2") in new stack
-- <SIP/101-0000000f> Playing 'study4/callAgain2.slin' (language 'en')
-- Executing [[email protected]:14] Goto("SIP/101-0000000f", "s,hang") in new stack
-- Goto (study4,s,57)
-- Executing [[email protected]:57] Hangup("SIP/101-0000000f", "") in new stack
== Spawn extension (study4, s, 57) exited non-zero on 'SIP/101-0000000f'
-- Executing [[email protected]:1] Verbose("SIP/101-0000000f", "2,"Hanging Up now"") in new stack
== "Hanging Up now"