update
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7871 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
2afd0fed8f
commit
5fae364cfd
|
@ -205,10 +205,15 @@ SWITCH_STANDARD_APP(transfer_function)
|
||||||
int argc;
|
int argc;
|
||||||
char *argv[4] = { 0 };
|
char *argv[4] = { 0 };
|
||||||
char *mydata;
|
char *mydata;
|
||||||
|
int bleg = 0, both = 0;
|
||||||
|
|
||||||
|
|
||||||
if (!switch_strlen_zero(data) && (mydata = switch_core_session_strdup(session, data))) {
|
if (!switch_strlen_zero(data) && (mydata = switch_core_session_strdup(session, data))) {
|
||||||
if ((argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0])))) >= 1) {
|
if ((argc = switch_separate_string(mydata, ' ', argv, (sizeof(argv) / sizeof(argv[0])))) >= 1) {
|
||||||
if (!strcasecmp(argv[0], "-bleg")) {
|
bleg = !strcasecmp(argv[0], "-bleg");
|
||||||
|
both = !strcasecmp(argv[0], "-both");
|
||||||
|
|
||||||
|
if (bleg || both) {
|
||||||
const char *uuid;
|
const char *uuid;
|
||||||
switch_channel_t *channel = switch_core_session_get_channel(session);
|
switch_channel_t *channel = switch_core_session_get_channel(session);
|
||||||
if ((uuid = switch_channel_get_variable(channel, SWITCH_SIGNAL_BOND_VARIABLE))) {
|
if ((uuid = switch_channel_get_variable(channel, SWITCH_SIGNAL_BOND_VARIABLE))) {
|
||||||
|
@ -218,6 +223,9 @@ SWITCH_STANDARD_APP(transfer_function)
|
||||||
switch_core_session_rwunlock(b_session);
|
switch_core_session_rwunlock(b_session);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (both) {
|
||||||
|
switch_ivr_session_transfer(session, argv[1], argv[2], argv[3]);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
switch_ivr_session_transfer(session, argv[0], argv[1], argv[2]);
|
switch_ivr_session_transfer(session, argv[0], argv[1], argv[2]);
|
||||||
}
|
}
|
||||||
|
|
|
@ -314,8 +314,9 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_parse_event(switch_core_session_t *se
|
||||||
if (!(stream = switch_channel_get_variable_partner(channel, SWITCH_HOLD_MUSIC_VARIABLE))) {
|
if (!(stream = switch_channel_get_variable_partner(channel, SWITCH_HOLD_MUSIC_VARIABLE))) {
|
||||||
stream = switch_channel_get_variable(channel, SWITCH_HOLD_MUSIC_VARIABLE);
|
stream = switch_channel_get_variable(channel, SWITCH_HOLD_MUSIC_VARIABLE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (stream) {
|
if (stream) {
|
||||||
switch_ivr_broadcast(b_uuid, hold_bleg, SMF_ECHO_ALEG | SMF_LOOP);
|
switch_ivr_broadcast(b_uuid, stream, SMF_ECHO_ALEG | SMF_LOOP);
|
||||||
} else {
|
} else {
|
||||||
b_uuid = NULL;
|
b_uuid = NULL;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1842,7 +1842,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_broadcast(const char *uuid, const cha
|
||||||
if ((flags & SMF_HOLD_BLEG)) {
|
if ((flags & SMF_HOLD_BLEG)) {
|
||||||
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "hold-bleg", "%s", "true");
|
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "hold-bleg", "%s", "true");
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_core_session_queue_private_event(other_session, &event);
|
switch_core_session_queue_private_event(other_session, &event);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1861,6 +1861,10 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_broadcast(const char *uuid, const cha
|
||||||
if ((flags & SMF_LOOP)) {
|
if ((flags & SMF_LOOP)) {
|
||||||
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "loops", "%d", -1);
|
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "loops", "%d", -1);
|
||||||
}
|
}
|
||||||
|
if ((flags & SMF_HOLD_BLEG)) {
|
||||||
|
switch_event_add_header(event, SWITCH_STACK_BOTTOM, "hold-bleg", "%s", "true");
|
||||||
|
}
|
||||||
|
|
||||||
switch_core_session_queue_private_event(session, &event);
|
switch_core_session_queue_private_event(session, &event);
|
||||||
}
|
}
|
||||||
master = session;
|
master = session;
|
||||||
|
|
Loading…
Reference in New Issue