From 3e0f3915a515ba83816e2156542fbd9f332ecfc8 Mon Sep 17 00:00:00 2001 From: Joshua Colp <jcolp@digium.com> Date: Tue, 19 Feb 2008 18:40:22 +0000 Subject: [PATCH] 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 --- CHANGES | 3 +++ UPGRADE.txt | 3 +++ apps/app_channelredirect.c | 11 +++++++---- 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/CHANGES b/CHANGES index d0cd4b3e33..d9059c84b1 100644 --- a/CHANGES +++ b/CHANGES @@ -366,6 +366,9 @@ Other Dialplan Application Changes * AMD() has a new "maximum word length" option. "show application AMD" from the CLI for more details * 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 --------------------- diff --git a/UPGRADE.txt b/UPGRADE.txt index d1832d52fe..46ab23db98 100644 --- a/UPGRADE.txt +++ b/UPGRADE.txt @@ -77,6 +77,9 @@ Applications: * ChanIsAvail() now has a 't' option, which allows the specified device to be queried for state without consulting the channel drivers. This 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 and is now deprecated. * DISA()'s fifth argument is now an options argument. If you have previously diff --git a/apps/app_channelredirect.c b/apps/app_channelredirect.c index 4629427243..ed7f2e43e5 100644 --- a/apps/app_channelredirect.c +++ b/apps/app_channelredirect.c @@ -39,8 +39,10 @@ static char *app = "ChannelRedirect"; static char *synopsis = "Redirects given channel to a dialplan target."; static char *descrip = "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) { @@ -69,11 +71,12 @@ static int asyncgoto_exec(struct ast_channel *chan, void *data) chan2 = ast_get_channel_by_name_locked(args.channel); if (!chan2) { 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); - + pbx_builtin_setvar_helper(chan, "CHANNELREDIRECT_STATUS", "SUCCESS"); ast_channel_unlock(chan2); return res; -- GitLab