# This is a BitKeeper generated diff -Nru style patch. # # ChangeSet # 2004/11/01 16:15:55-07:00 kpfleming@host-a.ph.star # app_dial.c: # add documentation # # apps/app_dial.c # 2004/11/01 16:15:51-07:00 kpfleming@host-a.ph.star +2 -0 # add documentation # # ChangeSet # 2004/11/01 14:55:59-07:00 kpfleming@host-a.ph.star # app_dial.c: # add OUTBOUND_GROUP support # # apps/app_dial.c # 2004/11/01 14:55:56-07:00 kpfleming@host-a.ph.star +10 -0 # add OUTBOUND_GROUP support # diff -Nru a/apps/app_dial.c b/apps/app_dial.c --- a/apps/app_dial.c 2004-11-01 16:16:03 -07:00 +++ b/apps/app_dial.c 2004-11-01 16:16:03 -07:00 @@ -93,6 +93,8 @@ " In addition to transferring the call, a call may be parked and then picked\n" "up by another user.\n" " The optional URL will be sent to the called party if the channel supports it.\n" +" If the OUTBOUND_GROUP variable is set, all peer channels created by this\n" +" application will be put into that group (as in SetGroup).\n" " This application sets the following channel variables upon completion:\n" " DIALEDTIME Time from dial to answer\n" " ANSWEREDTIME Time for actual call\n" @@ -484,6 +486,7 @@ int playargs=0, sentringing=0, moh=0; char *varname; int vartype; + char *outbound_group = NULL; int digit = 0; time_t start_time, answer_time, end_time; @@ -706,6 +709,10 @@ l = ""; ast_log(LOG_NOTICE, "Privacy DB is '%s', privacy is %d, clid is '%s'\n", privdb, privacy, l); } + + /* If a channel group has been specified, get it for use when we create peer channels */ + outbound_group = pbx_builtin_getvar_helper(chan, "OUTBOUND_GROUP"); + cur = peers; do { /* Remember where to start next time */ @@ -872,6 +879,11 @@ tmp->chan->adsicpe = chan->adsicpe; /* pass the digital flag */ ast_dup_flag(tmp->chan, chan, AST_FLAG_DIGITAL); + + /* If we have an outbound group, set this peer channel to it */ + if (outbound_group) + ast_app_group_set_channel(tmp->chan, outbound_group); + /* Place the call, but don't wait on the answer */ res = ast_call(tmp->chan, numsubst, 0);