2015-02-05 11 views
0

Я проектирую диалплан, как показано ниже. Все работает нормально, но расширение таймаута не работает.
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" 

ответ

0

Работает должным образом разработчиками.

опции таймаута будет работать только если у вас нет следующего расширения или все расширения неблокируемой в диалплане

exten=>s,n,WaitExten(10) 

exten=>i,1,Noop(invalid here) 
exten=>t,1,Noop(timeout here) 

ИЛИ

exten=>s,n,Background(somefile);non-blocking playback 

exten=>i,1,Noop(invalid here) 
exten=>t,1,Noop(timeout here) 

http://www.voip-info.org/wiki/view/Asterisk+tips+ivr+menu

 Смежные вопросы

  • Нет связанных вопросов^_^