[asterisk-users] Recording with MixMonitor and AGI

Henrik Westerberg henrik.westerberg at ain.se
Thu Mar 7 09:21:14 CST 2013


Hi,

I am developing a call recording application on Asterisk 11.2 and have this configuration in my dialplan:

[macro-ccdev2-rec]
exten => s,1,MixMonitor(${ARG1},b)

[outgoing-originate]
exten => _X.,1,NoOp(Will send call to ${EXTEN})
exten => _X.,n,Dial(SIP/${EXTEN}@x.y.z)

[outgoing-originate-rec]
exten => h,1,Agi(agi://localhost/ajpbx.agi?path=uploadrec&callid=${CC_CALLID})

exten => _X,1,NoOp(Will send call to ${EXTEN}, CC_CALLID is ${CC_CALLID}, CC_FILENAME is ${CC_FILENAME})
exten => _X,n,Dial(SIP/${EXTEN}@x.y.z,60,M(ccdev2-rec^${CC_FILENAME})e)

If I want to make a recorded server callout from 077777777 to 0888888888 I then originate a call via AMI to Local/077777777 at outgoing-originate with context set to outgoing-originate-rec and extension to 0888888888.
The result will be something like this:

    -- Executing [s at macro-ccdev2-rec:1] MixMonitor("SIP/upps-ccm-tq01-0000003f", "cbrec-15605.wav,b") in new stack
  == Begin MixMonitor Recording SIP/upps-ccm-tq01-0000003f
    -- Executing [h at outgoing-originate-rec:1] AGI("SIP/upps-ccm-tq01-0000003e", "agi://l4574/ajpbxtest.agi?path=uploadrec&callid=15605") in new stack
    -- <SIP/upps-ccm-tq01-0000003e>AGI Script agi://localhost/ajpbxtest.agi?path=uploadrec&callid=15605 completed, returning 0
    -- Executing [h at outgoing-originate-rec-dev2:1] AGI("SIP/upps-ccm-tq01-0000003f", "agi://4574/ajpbxtest.agi?path=uploadrec&callid=") in new stack
    -- <SIP/upps-ccm-tq01-0000003f>AGI Script agi://localhost/ajpbxtest.agi?path=uploadrec&callid= completed, returning 0
  == MixMonitor close filestream (mixed)
  == End MixMonitor Recording SIP/upps-ccm-tq01-0000003f

Unfortunately I get two different calls to the h extension, but this I can cope with. The one without called is not interesting.
The uploading will fail since the MixMonitor is still on when I try to upload the file. The file will not have a duration. It works when I schedule the uploading a while after from my agi application but I would rather not rely on a timeout.

When I tried to run StopMixMonitor before the Agi call in the h extension, the first call fail and I never get any uploading with callid.

    -- Executing [s at macro-ccdev2-rec:1] MixMonitor("SIP/upps-ccm-tq01-00000043", "cbrec-15607.wav,b") in new stack
  == Begin MixMonitor Recording SIP/upps-ccm-tq01-00000043
    -- Executing [h at outgoing-originate-rec-dev2:1] StopMixMonitor("SIP/upps-ccm-tq01-00000042", "") in new stack
  == Spawn extension (outgoing-originate-rec-dev2, h, 1) exited non-zero on 'SIP/upps-ccm-tq01-00000042'
    -- Executing [h at outgoing-originate-rec-dev2:1] StopMixMonitor("SIP/upps-ccm-tq01-00000043", "") in new stack
  == MixMonitor close filestream (mixed)
    -- Executing [h at outgoing-originate-rec-dev2:2] AGI("SIP/upps-ccm-tq01-00000043", "agi://localhost/ajpbxtest.agi?path=uploadrec&callid=") in new stack

Am I missing something here? I also looked at the possibility to specify a command to execute when MixMonitor stops but I would rather handle the file uploading in my agi application.

I also have another case: I want to dial out a call and record it. It will be a "oneway-call" from the server to a mobile. Do I need to get AGI-control of it and record with an AGI command or how can I hack it directly in the dial plan using MixMonitor?

Best Regards,
Henrik
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://lists.digium.com/pipermail/asterisk-users/attachments/20130307/d9b5a940/attachment.htm>


More information about the asterisk-users mailing list