mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-04-04 12:15:04 +00:00
[Core] Reuse caller profile
This commit is contained in:
parent
5aabb54f68
commit
dbc894d959
@ -1416,6 +1416,7 @@ CF_HOLD_BLEG - B leg is on hold
|
|||||||
CF_SERVICE - Channel has a service thread
|
CF_SERVICE - Channel has a service thread
|
||||||
CF_TAGGED - Channel is tagged
|
CF_TAGGED - Channel is tagged
|
||||||
CF_WINNER - Channel is the winner
|
CF_WINNER - Channel is the winner
|
||||||
|
CF_REUSE_CALLER_PROFILE - Channel reuse caller profile
|
||||||
CF_CONTROLLED - Channel is under control
|
CF_CONTROLLED - Channel is under control
|
||||||
CF_PROXY_MODE - Channel has no media
|
CF_PROXY_MODE - Channel has no media
|
||||||
CF_SUSPEND - Suspend i/o
|
CF_SUSPEND - Suspend i/o
|
||||||
@ -1468,6 +1469,7 @@ typedef enum {
|
|||||||
CF_SERVICE,
|
CF_SERVICE,
|
||||||
CF_TAGGED,
|
CF_TAGGED,
|
||||||
CF_WINNER,
|
CF_WINNER,
|
||||||
|
CF_REUSE_CALLER_PROFILE,
|
||||||
CF_CONTROLLED,
|
CF_CONTROLLED,
|
||||||
CF_PROXY_MODE,
|
CF_PROXY_MODE,
|
||||||
CF_PROXY_OFF,
|
CF_PROXY_OFF,
|
||||||
|
@ -1150,6 +1150,13 @@ SWITCH_STANDARD_APP(break_function)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SWITCH_STANDARD_APP(reuse_caller_profile_function)
|
||||||
|
{
|
||||||
|
switch_channel_t *channel;
|
||||||
|
channel = switch_core_session_get_channel(session);
|
||||||
|
switch_channel_set_flag(channel, CF_REUSE_CALLER_PROFILE);
|
||||||
|
}
|
||||||
|
|
||||||
SWITCH_STANDARD_APP(queue_dtmf_function)
|
SWITCH_STANDARD_APP(queue_dtmf_function)
|
||||||
{
|
{
|
||||||
switch_channel_queue_dtmf_string(switch_core_session_get_channel(session), (const char *) data);
|
switch_channel_queue_dtmf_string(switch_core_session_get_channel(session), (const char *) data);
|
||||||
@ -6551,6 +6558,7 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_dptools_load)
|
|||||||
SAF_SUPPORT_NOMEDIA);
|
SAF_SUPPORT_NOMEDIA);
|
||||||
SWITCH_ADD_APP(app_interface, "deflect", "Send call deflect", "Send a call deflect.", deflect_function, "<deflect_data>", SAF_SUPPORT_NOMEDIA);
|
SWITCH_ADD_APP(app_interface, "deflect", "Send call deflect", "Send a call deflect.", deflect_function, "<deflect_data>", SAF_SUPPORT_NOMEDIA);
|
||||||
SWITCH_ADD_APP(app_interface, "recovery_refresh", "Send call recovery_refresh", "Send a call recovery_refresh.", recovery_refresh_function, "", SAF_SUPPORT_NOMEDIA);
|
SWITCH_ADD_APP(app_interface, "recovery_refresh", "Send call recovery_refresh", "Send a call recovery_refresh.", recovery_refresh_function, "", SAF_SUPPORT_NOMEDIA);
|
||||||
|
SWITCH_ADD_APP(app_interface, "reuse_caller_profile", "Reuse the caller profile", "Reuse the caller profile", reuse_caller_profile_function, "", SAF_SUPPORT_NOMEDIA);
|
||||||
SWITCH_ADD_APP(app_interface, "queue_dtmf", "Queue dtmf to be sent", "Queue dtmf to be sent from a session", queue_dtmf_function, "<dtmf_data>",
|
SWITCH_ADD_APP(app_interface, "queue_dtmf", "Queue dtmf to be sent", "Queue dtmf to be sent from a session", queue_dtmf_function, "<dtmf_data>",
|
||||||
SAF_SUPPORT_NOMEDIA);
|
SAF_SUPPORT_NOMEDIA);
|
||||||
SWITCH_ADD_APP(app_interface, "send_dtmf", "Send dtmf to be sent", "Send dtmf to be sent from a session", send_dtmf_function, "<dtmf_data>",
|
SWITCH_ADD_APP(app_interface, "send_dtmf", "Send dtmf to be sent", "Send dtmf to be sent from a session", send_dtmf_function, "<dtmf_data>",
|
||||||
|
@ -2192,7 +2192,12 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_session_transfer(switch_core_session_
|
|||||||
extension = "service";
|
extension = "service";
|
||||||
}
|
}
|
||||||
|
|
||||||
new_profile = switch_caller_profile_clone(session, profile);
|
|
||||||
|
if (switch_channel_test_flag(channel, CF_REUSE_CALLER_PROFILE)){
|
||||||
|
new_profile = switch_channel_get_caller_profile(channel);
|
||||||
|
} else {
|
||||||
|
new_profile = switch_caller_profile_clone(session, profile);
|
||||||
|
}
|
||||||
|
|
||||||
new_profile->dialplan = switch_core_strdup(new_profile->pool, use_dialplan);
|
new_profile->dialplan = switch_core_strdup(new_profile->pool, use_dialplan);
|
||||||
new_profile->context = switch_core_strdup(new_profile->pool, use_context);
|
new_profile->context = switch_core_strdup(new_profile->pool, use_context);
|
||||||
@ -2238,7 +2243,9 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_session_transfer(switch_core_session_
|
|||||||
switch_core_session_rwunlock(other_session);
|
switch_core_session_rwunlock(other_session);
|
||||||
}
|
}
|
||||||
|
|
||||||
switch_channel_set_caller_profile(channel, new_profile);
|
if (!switch_channel_test_flag(channel, CF_REUSE_CALLER_PROFILE)){
|
||||||
|
switch_channel_set_caller_profile(channel, new_profile);
|
||||||
|
}
|
||||||
|
|
||||||
switch_channel_set_state(channel, CS_ROUTING);
|
switch_channel_set_state(channel, CS_ROUTING);
|
||||||
switch_channel_audio_sync(channel);
|
switch_channel_audio_sync(channel);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user