Asterisk Goto如果没有真正去

时间:2018-03-04 16:30:09

标签: asterisk pbx

如果SIP标头中有转移号码,我试图将拨号方案配置为GoTo不同的上下文。

这不起作用,因为它无声地失败了。 这是我的extensions.conf文件。

[from-external]
exten =>        _+<phone_number>,1,Noop(incoming call)
same =>         n,Answer()
same =>         n,Set(diversion=${SHELL(node ${scripts}/parsePhoneNumber.js ${SIP_HEADER(diversion)})})
same =>         n,GotoIf($["${diversion}" = ""]?1004,1:have_diversion])
same =>         n(have_diversion),Noop(in existing diversion)

[MissingDiversion]
exten =>            1004,1,Noop(in missing diversion)
same =>             n(missing_diversion_label),Noop(in missing diversion)

日志是:

== Using SIP RTP CoS mark 5
    -- Executing [+16167270007@from-external:1] NoOp("SIP/incoming-trunk2-00000021", "incoming call") in new stack
    -- Executing [+16167270007@from-external:2] Answer("SIP/incoming-trunk2-00000021", "") in new stack
    -- Executing [+16167270007@from-external:3] Set("SIP/incoming-trunk2-00000021", "diversion=") in new stack
    -- Executing [+16167270007@from-external:4] GotoIf("SIP/incoming-trunk2-00000021", "1?1004,1:have_diversion]") in new stack
    -- Goto (from-external,1004,1)

所以,看起来GOTO正在发挥作用,但它没有达到我希望它达到的地方。我没有看到in missing diversion的日志。

我尝试了GotoIf行的变种,但这些变体也不起作用:

same =>         n,GotoIf($["${diversion}" = ""]?
same =>         n,GotoIf($["${diversion}" = ""]?[MissingDiversion,1004]:have_diversion])
same =>         n,GotoIf($["${diversion}" = ""]?[MissingDiversion,1]:have_diversion])
same =>         n,GotoIf($["${diversion}" = ""]?[MissingDiversion,1004,1]:have_diversion])

另外,我只使用带有原始上下文[from-external]的标签 - GotoIf实际上有效。跳到新的背景是失败的。

我正在运行Asterisk 11.6

2 个答案:

答案 0 :(得分:2)

发现问题,在GotoIf语句的末尾是一个多余的额外']'。

应该是:

same =>         n,GotoIf($["${diversion}" = ""]?1004,1:have_diversion)

而不是:

same =>         n,GotoIf($["${diversion}" = ""]?1004,1:have_diversion])

答案 1 :(得分:0)

您应该将新上下文包含在外部,或者转到MissingDiversion,1004,1