fix att xfer to an app
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@15122 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
5b6d1cd33c
commit
539bccffe1
|
@ -802,6 +802,8 @@ SWITCH_DECLARE(switch_say_type_t) switch_ivr_get_say_type_by_name(const char *na
|
|||
SWITCH_DECLARE(switch_status_t) switch_ivr_set_user(switch_core_session_t *session, const char *data);
|
||||
SWITCH_DECLARE(switch_status_t) switch_ivr_sound_test(switch_core_session_t *session);
|
||||
SWITCH_DECLARE(void) switch_process_import(switch_core_session_t *session, switch_channel_t *peer_channel, const char *varname);
|
||||
SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_exists(const char *uuid);
|
||||
|
||||
/** @} */
|
||||
|
||||
SWITCH_END_EXTERN_C
|
||||
|
|
|
@ -3267,18 +3267,14 @@ SWITCH_STANDARD_API(uuid_setvar_multi_function)
|
|||
return SWITCH_STATUS_SUCCESS;
|
||||
}
|
||||
|
||||
#define EXISTS_SYNTAX "<uuid> <var>"
|
||||
#define EXISTS_SYNTAX "<uuid>"
|
||||
SWITCH_STANDARD_API(uuid_exists_function)
|
||||
{
|
||||
int exists = 0;
|
||||
|
||||
if (cmd) {
|
||||
switch_core_session_t *psession = NULL;
|
||||
if ((psession = switch_core_session_locate(cmd))) {
|
||||
switch_core_session_rwunlock(psession);
|
||||
exists = 1;
|
||||
}
|
||||
}
|
||||
switch_bool_t exists = SWITCH_FALSE;
|
||||
|
||||
if (cmd) {
|
||||
exists = switch_ivr_uuid_exists(cmd);
|
||||
}
|
||||
|
||||
stream->write_function(stream, "%s", exists ? "true" : "false");
|
||||
|
||||
|
|
|
@ -4247,6 +4247,14 @@ void sofia_handle_sip_i_refer(nua_t *nua, sofia_profile_t *profile, nua_handle_t
|
|||
br_a = switch_channel_get_variable(channel_a, SWITCH_SIGNAL_BOND_VARIABLE);
|
||||
br_b = switch_channel_get_variable(channel_b, SWITCH_SIGNAL_BOND_VARIABLE);
|
||||
|
||||
if (!switch_ivr_uuid_exists(br_a)) {
|
||||
br_a = NULL;
|
||||
}
|
||||
|
||||
if (!switch_ivr_uuid_exists(br_b)) {
|
||||
br_b = NULL;
|
||||
}
|
||||
|
||||
if (switch_channel_test_flag(channel_b, CF_ORIGINATOR)) {
|
||||
switch_core_session_t *a_session;
|
||||
|
||||
|
|
|
@ -2244,6 +2244,20 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_set_user(switch_core_session_t *sessi
|
|||
return status;
|
||||
}
|
||||
|
||||
SWITCH_DECLARE(switch_bool_t) switch_ivr_uuid_exists(const char *uuid)
|
||||
{
|
||||
switch_bool_t exists = SWITCH_FALSE;
|
||||
switch_core_session_t *psession = NULL;
|
||||
|
||||
if ((psession = switch_core_session_locate(uuid))) {
|
||||
switch_core_session_rwunlock(psession);
|
||||
exists = 1;
|
||||
}
|
||||
|
||||
return exists;
|
||||
}
|
||||
|
||||
|
||||
/* For Emacs:
|
||||
* Local Variables:
|
||||
* mode:c
|
||||
|
|
Loading…
Reference in New Issue