Asterisk Hangup Handler使用lua

时间:2016-08-29 13:16:02

标签: lua asterisk

我正在尝试在我的拨号计划中添加一个挂机处理程序,以通过拨打多个扩展程序来捕获未应答的呼叫。但不幸的是,我的挂机处理程序根本没有执行。 以下是我的 extensions.lua

CONSOLE = "Console/dsp" -- Console interface for demo
IAXINFO = "guest"       -- IAXtel username/password
TRUNK = "SIP"

GSMTRUNK = "Dongle/dongle0/"
PRITRUNK = "DAHDI/g0/"
TRUNKMSD = 1
local inspect = require ('inspect')
--from here onwards our logic is there Rajesh
function dialtomobind(number)
        app.Dial(GSMTRUNK..number, 50,'egb(add-hangup-handler^'..number..'^1)')
        local dialstatus = channel['DIALSTATUS']:get()
        app.NoOp('DIAL STATUS:'..dialstatus)
        app.Hangup(16)
end

function add_hangup_handler(context, extension)
        channel['hangup_handler_push']='hangup-handlers,s,1'
        app.NoOp('pre-dial handler, Adding Hangup Handler'..channel['hangup_handler_push']:get())
        app.Return()
end

function h_handler(context, extension)
        app.NoOp('After Hangup:'..extension)
        --app.DumpChan(3)
end

function directdialing(c,e)
        app.Answer(5)
        app.Playback('tt-monkeys')
        dialtomobind(string.sub(e, 4))
        app.Hangup(16)
end


function hangup_handler_1(c,e)
        --channel['hangup_handler_push']
        app.NoOp('Hangup Handler 1 Executed')
        app.Return()
end

extensions = {
        ['from-internal-sip']={
                ['h']=h_handler;
                ['_500XXXXXXXXXX']=directdialing;
        };
        ['dongle_incoming']={
                ['_.']=gsm_dongle_handler;
        };
        ['add-hangup-handler']={
                ['_.']=add_hangup_handler;
        };
        ['hangup-handlers']={
                ['_.']=hangup_handler_1;
        };
}

ASTERISK CLI OUT PUT:

    -- Executing [5008884882772@from-internal-sip:1] Answer("SIP/8884882772-00000047", "5")
       > 0x7f14c80072a0 -- Probation passed - setting RTP source address to 192.168.2.30:54032
[Aug 29 18:24:17] NOTICE[26470][C-000000c5]: res_rtp_asterisk.c:4478 ast_rtp_read: Unknown RTP codec 95 received from '192.168.2.30:54032'
    -- Executing [5008884882772@from-internal-sip:1] Playback("SIP/8884882772-00000047", "tt-monkeys")
    -- <SIP/8884882772-00000047> Playing 'tt-monkeys.gsm' (language 'en')
    -- Executing [5008884882772@from-internal-sip:1] Dial("SIP/8884882772-00000047", "Dongle/dongle0/8884882772,50,egb(add-hangup-handler^8884882772^1)")
    -- Dongle/dongle0-010000000e Internal Gosub(add-hangup-handler,8884882772,1) start
    -- Executing [8884882772@add-hangup-handler:1] NoOp("Dongle/dongle0-010000000e", "pre-dial handler, Adding Hangup Handlerhangup-handlers,s,1")
    -- Executing [8884882772@add-hangup-handler:1] Return("Dongle/dongle0-010000000e", "")
  == Spawn extension (dongle_incoming, 5008884882772, 1) exited non-zero on 'Dongle/dongle0-010000000e'
    -- Dongle/dongle0-010000000e Internal Gosub(add-hangup-handler,8884882772,1) complete GOSUB_RETVAL=
    -- Called Dongle/dongle0/8884882772
    -- Dongle/dongle0-010000000e is making progress passing it to SIP/8884882772-00000047
  == Spawn extension (from-internal-sip, 5008884882772, 1) exited non-zero on 'SIP/8884882772-00000047'
    -- Executing [h@from-internal-sip:1] NoOp("SIP/8884882772-00000047", "After Hangup:h")

2 个答案:

答案 0 :(得分:1)

Hangup处理程序是dialplan handler。

因此,如果您想使用它,请在挂起的上下文/扩展名中启动OTHER lua脚本。

扩展挂断处理程序,s,1有效且存在。

您已使用

app.Set('CHANNEL(hangup_handler)=hangup-handlers,s,1');

因为它不是变量,而是功能。

答案 1 :(得分:0)

  1. hangup_handler_push根本不是一个频道变量。因此无法使用以下方法进行访问。

    channel['hangup_handler_push']='hangup-handlers,s,1'
    

    channel['hangup_handler_push']='hangup-handlers,s,1'
    
  2. 要设置挂断处理程序,我们必须使用拨号计划功能CHANNEL(https://wiki.asterisk.org/wiki/display/AST/Hangup+Handlers)。所以下面的方法将起作用。

    channel.CHANNEL('hangup_handler_push'):set('hangup-handlers,s,1')
    
  3. Asterisk Set Application可用于设置通道变量以及也可以调用星号功能。所以下面的代码也在工作。

    app.Set('CHANNEL(hangup_handler)=hangup-handlers,s,1');
    
  4. 参考: Lua中的拨号计划功能 https://wiki.asterisk.org/wiki/pages/viewpage.action?pageId=16548029