mirror of
https://github.com/signalwire/freeswitch.git
synced 2025-03-13 04:36:42 +00:00
make the core pre_answer channels when they hit an app that requires media and they have not answered yet to at least establish media
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7525 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
d6851c0a41
commit
ccf4e57c8d
@ -473,6 +473,8 @@ SWITCH_DECLARE(switch_status_t) switch_channel_set_timestamps(_In_ switch_channe
|
|||||||
|
|
||||||
#define switch_channel_stop_broadcast(_channel) if (switch_channel_test_flag(_channel, CF_BROADCAST)) switch_channel_set_flag(_channel, CF_BREAK | CF_STOP_BROADCAST)
|
#define switch_channel_stop_broadcast(_channel) if (switch_channel_test_flag(_channel, CF_BROADCAST)) switch_channel_set_flag(_channel, CF_BREAK | CF_STOP_BROADCAST)
|
||||||
|
|
||||||
|
#define switch_channel_media_ready(_channel) ((switch_channel_test_flag(_channel, CF_ANSWERED) || switch_channel_test_flag(_channel, CF_EARLY_MEDIA)) && !switch_channel_test_flag(_channel, CF_BYPASS_MEDIA))
|
||||||
|
|
||||||
/** @} */
|
/** @} */
|
||||||
|
|
||||||
SWITCH_END_EXTERN_C
|
SWITCH_END_EXTERN_C
|
||||||
|
@ -156,8 +156,12 @@ static void switch_core_standard_on_execute(switch_core_session_t *session)
|
|||||||
if (switch_channel_test_flag(session->channel, CF_BYPASS_MEDIA) && !switch_test_flag(application_interface, SAF_SUPPORT_NOMEDIA)) {
|
if (switch_channel_test_flag(session->channel, CF_BYPASS_MEDIA) && !switch_test_flag(application_interface, SAF_SUPPORT_NOMEDIA)) {
|
||||||
switch_ivr_media(session->uuid_str, SMF_NONE);
|
switch_ivr_media(session->uuid_str, SMF_NONE);
|
||||||
nomedia++;
|
nomedia++;
|
||||||
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Application %s Requires media!\n",
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Application %s Requires media on channel %s!\n",
|
||||||
extension->current_application->application_name);
|
extension->current_application->application_name, switch_channel_get_name(session->channel));
|
||||||
|
} else if (!switch_channel_media_ready(session->channel)) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_ERROR, "Application %s Requires media! pre_answering channel %s\n",
|
||||||
|
extension->current_application->application_name, switch_channel_get_name(session->channel));
|
||||||
|
switch_channel_pre_answer(session->channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((expanded =
|
if ((expanded =
|
||||||
|
Loading…
x
Reference in New Issue
Block a user