Mike Coakley wrote:
Chris,

Actually it is a documented feature of Macro. Macro only executes extension "s" there are no other extensions in the macro context. I ran into this while working through building our dial plan. It was driving me nutz. (But the WIKI rescued me.) What I had to do is use the Macro to setup the call as needed and then Goto a context that had all the extensions I needed.

For a complete example:

I wanted to be able to call an station and if that station didn't answer I wanted to present the user with a menu that they could press #1 to leave a voicemail, #2 to try again, #4 to go to the main menu, #8 to call the group/department the station belongs to, #9 to go to the group/department directory or #0 to go to operator. Here is what I had to do BECAUSE Macro can only execute the "s" extension.

[macro-stationcall]
exten => s,1,SetVar(STATION_EXT=${ARG1})
exten => s,2,SetVar(STATION_MAILBOX=${ARG2})
exten => s,3,SetVar(STATION_GROUP=${ARG3})
exten => s,4,SetVar(STATION_MENU=${ARG4})
exten => s,5,SetVar(STATION_DIRECTORY=${ARG5})
exten => s,6,Goto(stationcall_menu,s,1)

[stationcall_menu]
exten => s,1,Answer
exten => s,2,Wait(1)
exten => s,3,DigitTimeout(5)
exten => s,4,ResponseTimeout(5)
exten => s,5,AbsoluteTimeout(30)
exten => s,6,Dial(${STATION_EXT})
exten => s,7,Background(${STATION_MENU})
exten => 1,1,Voicemail(u${STATION_MAILBOX})
exten => 2,1,Goto(s,6)
exten => 4,1,Goto(main_menu,s,1)
exten => 8,1,Macro(groupcall,${STATION_GROU})
exten => 9,1,Directory(${STATION_DIRECTORY})
exten => 0,1,Goto(operator,s,1)
exten => i,1,Playback(invalid)
exten => i,2,Goto(s,7)
exten => t,1,Goto(s,7)
exten => T,1,Hangup

I simplified this example (trust me) but I hope you get the idea. Also realize that SetVar puts a variable in the scope of the current call.

Hope this helps.

Mike

On Aug 10, 2004, at 5:59 PM, Christopher L. Wade wrote:

Okay, time for an update.

I posted this as a bug. Very quickly got informed that it is not a bug, but instead, an undocumented 'feature'.

AbsoluteTimeout is treated as an *exception* (ie it looks like a hangup) by most applications, including Macro, which makes most applications exit.

This being said, this is why a 'T' extension in the calling context would run, but not a 'T' extension inside the macro. Once macro exists, the macro context no longer exists, and the 'T' extension inside the macro becomes 'inaccessible'.

Oh well, I guess I'll have to implement my logic without macros. Hopefully variables aren't screwed up by AbsoluteTimeout.

Thanks,
Chris


Well, according to the wiki - see the macro-stdexten, 's' is not the only extension that can be used within a macro. The stdexten macro uses Goto and ${DIALSTATUS} to branch to s-${DIALSTATUS} (you can change this to just ${DIALSTATUS} if you want, it still works, but pattern matching that to group unhandled values isn't as clean and recognizable as 's-.' is.


Also, the following example shows you can branch as much as you like inside a macro:

[macro-testM]
exten => s,1,Goto(test,1)
exten => test,1,NoOp(${CONTEXT},${MACRO_CONTEXT})

This macro, when run, will print the following assuming you start asterisk CLI with verbosity high enough and debug on (I always start it this way).

Executing NoOp("Zap/1-1", "macro-testM|internal") in new stack

So, again, the wiki is "wrong". Well, not quite, the wiki is right in that you *must* have the 's' extension and that this is where your macro execution will *always* start. But, once inside the macro, you can do just about anything you want, except use exceptions.

Thanks,
Chris

_______________________________________________
Asterisk-Users mailing list
[EMAIL PROTECTED]
http://lists.digium.com/mailman/listinfo/asterisk-users
To UNSUBSCRIBE or update options visit:
  http://lists.digium.com/mailman/listinfo/asterisk-users

Reply via email to