git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7421 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Michael Jerris 2008-01-29 17:48:10 +00:00
parent 3046c27bda
commit 1e691217f3
1 changed files with 49 additions and 60 deletions

View File

@ -190,9 +190,6 @@ SWITCH_STANDARD_API(find_user_function)
return _find_user(cmd, session, stream, SWITCH_FALSE); return _find_user(cmd, session, stream, SWITCH_FALSE);
} }
SWITCH_STANDARD_API(xml_locate_function) SWITCH_STANDARD_API(xml_locate_function)
{ {
switch_xml_t xml = NULL, obj = NULL; switch_xml_t xml = NULL, obj = NULL;
@ -218,8 +215,7 @@ SWITCH_STANDARD_API(xml_locate_function)
goto end; goto end;
} }
mydata = strdup(cmd);
mydata = strdup(cmd);
switch_assert(mydata); switch_assert(mydata);
argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0]))); argc = switch_separate_string(mydata, delim, argv, (sizeof(argv) / sizeof(argv[0])));
@ -253,9 +249,7 @@ SWITCH_STANDARD_API(xml_locate_function)
goto end; goto end;
} }
end:
end:
switch_event_destroy(&params); switch_event_destroy(&params);
if (err) { if (err) {
@ -306,7 +300,6 @@ SWITCH_STANDARD_API(regex_function)
goto error; goto error;
} }
if ((proceed = switch_regex_perform(argv[0], argv[1], &re, ovector, sizeof(ovector) / sizeof(ovector[0])))) { if ((proceed = switch_regex_perform(argv[0], argv[1], &re, ovector, sizeof(ovector) / sizeof(ovector[0])))) {
if (argc > 2) { if (argc > 2) {
len = strlen(argv[0]) * 3; len = strlen(argv[0]) * 3;
@ -335,7 +328,6 @@ SWITCH_STANDARD_API(regex_function)
switch_safe_free(mydata); switch_safe_free(mydata);
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }
typedef enum { typedef enum {
@ -462,8 +454,6 @@ SWITCH_STANDARD_API(cond_function)
switch_safe_free(mydata); switch_safe_free(mydata);
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }
@ -598,7 +588,6 @@ SWITCH_STANDARD_API(ctl_function)
goto end; goto end;
} }
stream->write_function(stream, "+OK\n"); stream->write_function(stream, "+OK\n");
end: end:
free(mydata); free(mydata);
@ -725,65 +714,65 @@ SWITCH_STANDARD_API(transfer_function)
switch_core_session_t *tsession = NULL, *other_session = NULL; switch_core_session_t *tsession = NULL, *other_session = NULL;
char *mycmd = NULL, *argv[5] = { 0 }; char *mycmd = NULL, *argv[5] = { 0 };
int argc = 0; int argc = 0;
char *tuuid = argv[0];
char *dest = argv[1];
char *dp = argv[2];
char *context = argv[3];
char *arg = NULL;
if (session) { if (session) {
return SWITCH_STATUS_FALSE; return SWITCH_STATUS_FALSE;
} }
if (!switch_strlen_zero(cmd) && (mycmd = strdup(cmd))) { if (switch_strlen_zero(cmd) || !(mycmd = strdup(cmd))) {
argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0]))); stream->write_function(stream, "-USAGE: %s\n", TRANSFER_SYNTAX);
if (argc >= 2 && argc <= 5) { return SWITCH_STATUS_SUCCESS;
char *tuuid = argv[0]; }
char *dest = argv[1];
char *dp = argv[2];
char *context = argv[3];
char *arg = NULL;
if ((tsession = switch_core_session_locate(tuuid))) { argc = switch_separate_string(mycmd, ' ', argv, (sizeof(argv) / sizeof(argv[0])));
if (argc < 2 || argc > 5) {
stream->write_function(stream, "-USAGE: %s\n", TRANSFER_SYNTAX);
goto done;
}
if (*dest == '-') { if (!(tsession = switch_core_session_locate(tuuid))) {
arg = dest; stream->write_function(stream, "-ERR No Such Channel!\n");
dest = argv[2]; goto done;
dp = argv[3]; }
context = argv[4];
}
if (arg) { if (*dest == '-') {
switch_channel_t *channel = switch_core_session_get_channel(tsession); arg = dest;
arg++; dest = argv[2];
if (!strcasecmp(arg, "bleg")) { dp = argv[3];
const char *uuid = switch_channel_get_variable(channel, SWITCH_BRIDGE_VARIABLE); context = argv[4];
if (uuid && (other_session = switch_core_session_locate(uuid))) { }
switch_core_session_t *tmp = tsession;
tsession = other_session;
other_session = NULL;
switch_core_session_rwunlock(tmp);
}
} else if (!strcasecmp(arg, "both")) {
const char *uuid = switch_channel_get_variable(channel, SWITCH_BRIDGE_VARIABLE);
if (uuid && (other_session = switch_core_session_locate(uuid))) {
switch_ivr_session_transfer(other_session, dest, dp, context);
switch_core_session_rwunlock(other_session);
}
}
}
if (switch_ivr_session_transfer(tsession, dest, dp, context) == SWITCH_STATUS_SUCCESS) { if (arg) {
stream->write_function(stream, "+OK\n"); switch_channel_t *channel = switch_core_session_get_channel(tsession);
} else { const char *uuid = switch_channel_get_variable(channel, SWITCH_BRIDGE_VARIABLE);
stream->write_function(stream, "-ERR\n"); arg++;
} if (!strcasecmp(arg, "bleg")) {
if (uuid && (other_session = switch_core_session_locate(uuid))) {
switch_core_session_rwunlock(tsession); switch_core_session_t *tmp = tsession;
tsession = other_session;
} else { other_session = NULL;
stream->write_function(stream, "-ERR No Such Channel!\n"); switch_core_session_rwunlock(tmp);
}
} else if (!strcasecmp(arg, "both")) {
if (uuid && (other_session = switch_core_session_locate(uuid))) {
switch_ivr_session_transfer(other_session, dest, dp, context);
switch_core_session_rwunlock(other_session);
} }
goto done;
} }
} }
stream->write_function(stream, "-USAGE: %s\n", TRANSFER_SYNTAX); if (switch_ivr_session_transfer(tsession, dest, dp, context) == SWITCH_STATUS_SUCCESS) {
stream->write_function(stream, "+OK\n");
} else {
stream->write_function(stream, "-ERR\n");
}
switch_core_session_rwunlock(tsession);
done: done:
switch_safe_free(mycmd); switch_safe_free(mycmd);