[svn-commits] file: trunk r51592 - in /trunk: ./ apps/ doc/
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Mon Jan 22 21:45:44 MST 2007
Author: file
Date: Mon Jan 22 22:45:43 2007
New Revision: 51592
URL: http://svn.digium.com/view/asterisk?view=rev&rev=51592
Log:
Make 'H' command do as advertised and add 'E' and 'V' commands to ExternalIVR. (issue #8165 reported by mnicholson)
Modified:
trunk/CHANGES
trunk/apps/app_externalivr.c
trunk/doc/externalivr.txt
Modified: trunk/CHANGES
URL: http://svn.digium.com/view/asterisk/trunk/CHANGES?view=diff&rev=51592&r1=51591&r2=51592
==============================================================================
--- trunk/CHANGES (original)
+++ trunk/CHANGES Mon Jan 22 22:45:43 2007
@@ -65,6 +65,7 @@
* Added the parkedcalltransfers option to features.conf
* Added 's' option to Page application.
* Added the srvlookup option to iax.conf
+ * Added 'E' and 'V' commands to ExternalIVR.
SIP changes
-----------
Modified: trunk/apps/app_externalivr.c
URL: http://svn.digium.com/view/asterisk/trunk/apps/app_externalivr.c?view=diff&rev=51592&r1=51591&r2=51592
==============================================================================
--- trunk/apps/app_externalivr.c (original)
+++ trunk/apps/app_externalivr.c Mon Jan 22 22:45:43 2007
@@ -487,9 +487,15 @@
AST_LIST_INSERT_TAIL(&u->playlist, entry, list);
AST_LIST_UNLOCK(&u->playlist);
}
+ } else if (input[0] == 'E') {
+ ast_chan_log(LOG_NOTICE, chan, "Exiting: %s\n", &input[2]);
+ send_child_event(child_events, 'E', NULL, chan);
+ res = 0;
+ break;
} else if (input[0] == 'H') {
ast_chan_log(LOG_NOTICE, chan, "Hanging up: %s\n", &input[2]);
send_child_event(child_events, 'H', NULL, chan);
+ res = -1;
break;
} else if (input[0] == 'O') {
if (!strcasecmp(&input[2], "autoclear"))
@@ -498,6 +504,15 @@
u->option_autoclear = 0;
else
ast_chan_log(LOG_WARNING, chan, "Unknown option requested '%s'\n", &input[2]);
+ } else if (input[0] == 'V') {
+ char *c;
+ c = strchr(&input[2], '=');
+ if (!c) {
+ send_child_event(child_events, 'Z', NULL, chan);
+ } else {
+ *c++ = '\0';
+ pbx_builtin_setvar_helper(chan, &input[2], c);
+ }
}
} else if (ready_fd == child_errors_fd) {
char input[1024];
Modified: trunk/doc/externalivr.txt
URL: http://svn.digium.com/view/asterisk/trunk/doc/externalivr.txt?view=diff&rev=51592&r1=51591&r2=51592
==============================================================================
--- trunk/doc/externalivr.txt (original)
+++ trunk/doc/externalivr.txt Mon Jan 22 22:45:43 2007
@@ -55,6 +55,7 @@
*: DTMF event for key *
#: DTMF event for key #
H: the channel was hung up by the connected party
+E: the script requested an exit
Z: the previous command was unable to be executed (file does not
exist, etc.)
T: the play list was interrupted (see below)
@@ -76,7 +77,9 @@
S,filename
A,filename
H,message
+E,message
O,option
+V,name=value
The 'S' command checks to see if there is a playable audio file with
the specified name, and if so, clear's the generator's playlist and
@@ -93,6 +96,9 @@
playlist. The same playability and exception rules apply as for the
'S' command.
+The 'E' command stops the generator and continues execution in the dialplan,
+and logs the supplied message to the Asterisk log.
+
The 'H' command stops the generator and hangs up the channel, and logs
the supplied message to the Asterisk log.
@@ -102,6 +108,8 @@
Automatically interrupt and clear the playlist upon reception
of DTMF input.
+The 'V' command sets the specified channel variable to the specified value.
+
Errors
------
More information about the svn-commits
mailing list