Skip to content
Snippets Groups Projects
Commit 8f537c43 authored by Kevin P. Fleming's avatar Kevin P. Fleming
Browse files

add status variable output and jumping control to SendURL() (issue #4812)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@6581 65c4cc65-6c06-0410-ace0-fbb531ad65f3
parent 7b0c1cb2
No related branches found
No related tags found
No related merge requests found
...@@ -26,6 +26,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") ...@@ -26,6 +26,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
#include "asterisk/module.h" #include "asterisk/module.h"
#include "asterisk/translate.h" #include "asterisk/translate.h"
#include "asterisk/image.h" #include "asterisk/image.h"
#include "asterisk/options.h"
static char *tdesc = "Send URL Applications"; static char *tdesc = "Send URL Applications";
...@@ -34,15 +35,25 @@ static char *app = "SendURL"; ...@@ -34,15 +35,25 @@ static char *app = "SendURL";
static char *synopsis = "Send a URL"; static char *synopsis = "Send a URL";
static char *descrip = static char *descrip =
" SendURL(URL[|option]): Requests client go to URL. If the client\n" " SendURL(URL[|option]): Requests client go to URL (IAX2) or sends the \n"
"does not support html transport, and there exists a step with\n" "URL to the client (other channels).\n"
"priority n + 101, then execution will continue at that step.\n" "Result is returned in the SENDURLSTATUS channel variable:\n"
"Otherwise, execution will continue at the next priority level.\n" " SUCCESS URL successfully sent to client\n"
"SendURL only returns 0 if the URL was sent correctly or if\n" " FAILURE Failed to send URL\n"
"the channel does not support HTML transport, and -1 otherwise.\n" " NOLOAD Clien failed to load URL (wait enabled)\n"
"If the option 'wait' is specified, execution will wait for an\n" " UNSUPPORTED Channel does not support URL transport\n"
"acknowledgement that the URL has been loaded before continuing\n" "\n"
"and will return -1 if the peer is unable to load the URL\n"; "If the option 'wait' is specified, execution will wait for an\n"
"acknowledgement that the URL has been loaded before continuing\n"
"and will return -1 if the peer is unable to load the URL\n"
"\n"
"Old behaviour (deprecated): \n"
" If the client does not support Asterisk \"html\" transport, \n"
" and there exists a step with priority n + 101, then execution will\n"
" continue at that step.\n"
" Otherwise, execution will continue at the next priority level.\n"
" SendURL only returns 0 if the URL was sent correctly or if\n"
" the channel does not support HTML transport, and -1 otherwise.\n";
STANDARD_LOCAL_USER; STANDARD_LOCAL_USER;
...@@ -54,11 +65,15 @@ static int sendurl_exec(struct ast_channel *chan, void *data) ...@@ -54,11 +65,15 @@ static int sendurl_exec(struct ast_channel *chan, void *data)
struct localuser *u; struct localuser *u;
char tmp[256]; char tmp[256];
char *options; char *options;
int option_wait=0; int local_option_wait=0;
int local_option_jump = 0;
struct ast_frame *f; struct ast_frame *f;
char *stringp=NULL; char *stringp=NULL;
char *status = "FAILURE";
if (!data || !strlen((char *)data)) { if (!data || !strlen((char *)data)) {
ast_log(LOG_WARNING, "SendURL requires an argument (URL)\n"); ast_log(LOG_WARNING, "SendURL requires an argument (URL)\n");
pbx_builtin_setvar_helper(chan, "SENDURLSTATUS", status);
return -1; return -1;
} }
strncpy(tmp, (char *)data, sizeof(tmp)-1); strncpy(tmp, (char *)data, sizeof(tmp)-1);
...@@ -66,51 +81,62 @@ static int sendurl_exec(struct ast_channel *chan, void *data) ...@@ -66,51 +81,62 @@ static int sendurl_exec(struct ast_channel *chan, void *data)
strsep(&stringp, "|"); strsep(&stringp, "|");
options = strsep(&stringp, "|"); options = strsep(&stringp, "|");
if (options && !strcasecmp(options, "wait")) if (options && !strcasecmp(options, "wait"))
option_wait = 1; local_option_wait = 1;
if (options && !strcasecmp(options, "j"))
local_option_jump = 1;
LOCAL_USER_ADD(u); LOCAL_USER_ADD(u);
if (!ast_channel_supports_html(chan)) { if (!ast_channel_supports_html(chan)) {
/* Does not support transport */ /* Does not support transport */
if (ast_exists_extension(chan, chan->context, chan->exten, chan->priority + 101, chan->cid.cid_num)) if (local_option_jump || option_priority_jumping)
chan->priority += 100; ast_goto_if_exists(chan, chan->context, chan->exten, chan->priority + 101);
pbx_builtin_setvar_helper(chan, "SENDURLSTATUS", "UNSUPPORTED");
LOCAL_USER_REMOVE(u); LOCAL_USER_REMOVE(u);
return 0; return 0;
} }
res = ast_channel_sendurl(chan, tmp); res = ast_channel_sendurl(chan, tmp);
if (res > -1) { if (res == -1) {
if (option_wait) { pbx_builtin_setvar_helper(chan, "SENDURLSTATUS", "FAILURE");
for(;;) { LOCAL_USER_REMOVE(u);
/* Wait for an event */ return res;
res = ast_waitfor(chan, -1); }
if (res < 0) status = "SUCCESS";
if (local_option_wait) {
for(;;) {
/* Wait for an event */
res = ast_waitfor(chan, -1);
if (res < 0)
break;
f = ast_read(chan);
if (!f) {
res = -1;
status = "FAILURE";
break;
}
if (f->frametype == AST_FRAME_HTML) {
switch(f->subclass) {
case AST_HTML_LDCOMPLETE:
res = 0;
ast_frfree(f);
status = "NOLOAD";
goto out;
break; break;
f = ast_read(chan); case AST_HTML_NOSUPPORT:
if (!f) { /* Does not support transport */
res = -1; status ="UNSUPPORTED";
if (local_option_jump || option_priority_jumping)
ast_goto_if_exists(chan, chan->context, chan->exten, chan->priority + 101);
res = 0;
goto out;
break; break;
} default:
if (f->frametype == AST_FRAME_HTML) { ast_log(LOG_WARNING, "Don't know what to do with HTML subclass %d\n", f->subclass);
switch(f->subclass) { };
case AST_HTML_LDCOMPLETE:
res = 0;
ast_frfree(f);
goto out;
break;
case AST_HTML_NOSUPPORT:
/* Does not support transport */
if (ast_exists_extension(chan, chan->context, chan->exten, chan->priority + 101, chan->cid.cid_num))
chan->priority += 100;
res = 0;
goto out;
break;
default:
ast_log(LOG_WARNING, "Don't know what to do with HTML subclass %d\n", f->subclass);
};
}
ast_frfree(f);
} }
ast_frfree(f);
} }
} }
out: out:
pbx_builtin_setvar_helper(chan, "SENDURLSTATUS", status);
LOCAL_USER_REMOVE(u); LOCAL_USER_REMOVE(u);
return res; return res;
} }
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Please register or to comment