[Freeswitch-svn] [commit] r5770 - in freeswitch/trunk/src: . mod/applications/mod_commands
Freeswitch SVN
anthm at freeswitch.org
Mon Oct 1 10:57:16 EDT 2007
Author: anthm
Date: Mon Oct 1 10:57:15 2007
New Revision: 5770
Modified:
freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
freeswitch/trunk/src/switch_ivr.c
Log:
add -bleg and -both flags to the transfer api command so you can transfer both sides or the opposite side of a call as well
Modified: freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c
==============================================================================
--- freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c (original)
+++ freeswitch/trunk/src/mod/applications/mod_commands/mod_commands.c Mon Oct 1 10:57:15 2007
@@ -218,11 +218,11 @@
return SWITCH_STATUS_SUCCESS;
}
-#define TRANSFER_SYNTAX "<uuid> <dest-exten> [<dialplan>] [<context>]"
+#define TRANSFER_SYNTAX "<uuid> [-bleg|-both] <dest-exten> [<dialplan>] [<context>]"
SWITCH_STANDARD_API(transfer_function)
{
- switch_core_session_t *tsession = NULL;
- char *mycmd = NULL, *argv[4] = { 0 };
+ switch_core_session_t *tsession = NULL, *other_session = NULL;
+ char *mycmd = NULL, *argv[5] = { 0 };
int argc = 0;
if (session) {
@@ -236,9 +236,38 @@
char *dest = argv[1];
char *dp = argv[2];
char *context = argv[3];
+ char *arg = NULL;
if ((tsession = switch_core_session_locate(uuid))) {
+ if (*dest == '-') {
+ arg = dest;
+ dest = argv[2];
+ dp = argv[3];
+ context = argv[4];
+ }
+
+ if (arg) {
+ switch_channel_t *channel = switch_core_session_get_channel(tsession);
+ arg++;
+ if (!strcasecmp(arg, "bleg")) {
+ char *uuid = switch_channel_get_variable(channel, SWITCH_BRIDGE_VARIABLE);
+ 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")) {
+ char *uuid = switch_channel_get_variable(channel, SWITCH_BRIDGE_VARIABLE);
+ switch_core_session_t *other_session;
+ 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) {
stream->write_function(stream, "OK\n");
} else {
@@ -246,7 +275,7 @@
}
switch_core_session_rwunlock(tsession);
-
+
} else {
stream->write_function(stream, "No Such Channel!\n");
}
Modified: freeswitch/trunk/src/switch_ivr.c
==============================================================================
--- freeswitch/trunk/src/switch_ivr.c (original)
+++ freeswitch/trunk/src/switch_ivr.c Mon Oct 1 10:57:15 2007
@@ -895,6 +895,8 @@
}
if (uuid && (other_session = switch_core_session_locate(uuid))) {
+ other_channel = switch_core_session_get_channel(other_session);
+ assert(other_channel != NULL);
switch_channel_set_variable(other_channel, SWITCH_SIGNAL_BOND_VARIABLE, NULL);
switch_core_session_rwunlock(other_session);
}
More information about the Freeswitch-svn
mailing list