Skip to content
Snippets Groups Projects
Commit 3e0f3915 authored by Joshua Colp's avatar Joshua Colp
Browse files

Add CHANNELREDIRECT_STATUS variable to ChannelRedirect() dialplan application....

Add CHANNELREDIRECT_STATUS variable to ChannelRedirect() dialplan application. This will either be set to NOCHANNEL if the given channel was not found or SUCCESS if it worked.
(closes issue #11553)
Reported by: johan
Patches:
      UPGRADE.txt.channelredirect.patch uploaded by johan (license 334)
      CHANGES.channelredirect.patch uploaded by johan (license 334)
      app_channelredirect-20080219.patch uploaded by johan (license 334)


git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@103819 65c4cc65-6c06-0410-ace0-fbb531ad65f3
parent 19d238de
No related branches found
No related tags found
No related merge requests found
...@@ -366,6 +366,9 @@ Other Dialplan Application Changes ...@@ -366,6 +366,9 @@ Other Dialplan Application Changes
* AMD() has a new "maximum word length" option. "show application AMD" from the CLI * AMD() has a new "maximum word length" option. "show application AMD" from the CLI
for more details for more details
* GotoIfTime() now may branch based on a "false" condition, like other Goto-related applications * GotoIfTime() now may branch based on a "false" condition, like other Goto-related applications
* The ChannelRedirect application no longer exits the dialplan if the given channel
does not exist. It will now set the CHANNELREDIRECT_STATUS variable to SUCCESS upon success
or NOCHANNEL if the given channel was not found.
Music On Hold Changes Music On Hold Changes
--------------------- ---------------------
......
...@@ -77,6 +77,9 @@ Applications: ...@@ -77,6 +77,9 @@ Applications:
* ChanIsAvail() now has a 't' option, which allows the specified device * ChanIsAvail() now has a 't' option, which allows the specified device
to be queried for state without consulting the channel drivers. This to be queried for state without consulting the channel drivers. This
performs mostly a 'ChanExists' sort of function. performs mostly a 'ChanExists' sort of function.
* ChannelRedirect() will not terminate the channel that fails to do a
channelredirect as it has done previously. Instead CHANNELREDIRECT_STATUS
will reflect if the attempt was successful of not.
* SetCallerPres() has been replaced with the CALLERPRES() dialplan function * SetCallerPres() has been replaced with the CALLERPRES() dialplan function
and is now deprecated. and is now deprecated.
* DISA()'s fifth argument is now an options argument. If you have previously * DISA()'s fifth argument is now an options argument. If you have previously
......
...@@ -39,8 +39,10 @@ static char *app = "ChannelRedirect"; ...@@ -39,8 +39,10 @@ static char *app = "ChannelRedirect";
static char *synopsis = "Redirects given channel to a dialplan target."; static char *synopsis = "Redirects given channel to a dialplan target.";
static char *descrip = static char *descrip =
"ChannelRedirect(channel,[[context,]extension,]priority)\n" "ChannelRedirect(channel,[[context,]extension,]priority)\n"
" Sends the specified channel to the specified extension priority\n"; " Sends the specified channel to the specified extension priority\n"
"This application sets the following channel variables upon completion:\n"
" CHANNELREDIRECT_STATUS - Are set to the result of the redirection\n"
" either NOCHANNEL or SUCCESS\n";
static int asyncgoto_exec(struct ast_channel *chan, void *data) static int asyncgoto_exec(struct ast_channel *chan, void *data)
{ {
...@@ -69,11 +71,12 @@ static int asyncgoto_exec(struct ast_channel *chan, void *data) ...@@ -69,11 +71,12 @@ static int asyncgoto_exec(struct ast_channel *chan, void *data)
chan2 = ast_get_channel_by_name_locked(args.channel); chan2 = ast_get_channel_by_name_locked(args.channel);
if (!chan2) { if (!chan2) {
ast_log(LOG_WARNING, "No such channel: %s\n", args.channel); ast_log(LOG_WARNING, "No such channel: %s\n", args.channel);
return -1; pbx_builtin_setvar_helper(chan, "CHANNELREDIRECT_STATUS", "NOCHANNEL");
return 0;
} }
res = ast_async_parseable_goto(chan2, args.label); res = ast_async_parseable_goto(chan2, args.label);
pbx_builtin_setvar_helper(chan, "CHANNELREDIRECT_STATUS", "SUCCESS");
ast_channel_unlock(chan2); ast_channel_unlock(chan2);
return res; return res;
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment