normalize tests for outbound channels to use switch_channel_direction instead of testing for CF_OUTBOUND
This commit is contained in:
parent
00046ee0f2
commit
93cc3dc556
|
@ -2456,7 +2456,7 @@ static void conference_loop_output(conference_member_t *member)
|
||||||
switch_event_destroy(&event);
|
switch_event_destroy(&event);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
/* test to see if outbound channel has answered */
|
/* test to see if outbound channel has answered */
|
||||||
if (switch_channel_test_flag(channel, CF_ANSWERED) && !switch_test_flag(member->conference, CFLAG_ANSWERED)) {
|
if (switch_channel_test_flag(channel, CF_ANSWERED) && !switch_test_flag(member->conference, CFLAG_ANSWERED)) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(member->session), SWITCH_LOG_DEBUG,
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(member->session), SWITCH_LOG_DEBUG,
|
||||||
|
@ -2599,7 +2599,7 @@ static void conference_loop_output(conference_member_t *member)
|
||||||
switch_channel_cause2str(switch_channel_get_cause(channel)));
|
switch_channel_cause2str(switch_channel_get_cause(channel)));
|
||||||
|
|
||||||
/* if it's an outbound channel, store the release cause in the conference struct, we might need it */
|
/* if it's an outbound channel, store the release cause in the conference struct, we might need it */
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
member->conference->bridge_hangup_cause = switch_channel_get_cause(channel);
|
member->conference->bridge_hangup_cause = switch_channel_get_cause(channel);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5446,7 +5446,7 @@ SWITCH_STANDARD_APP(conference_function)
|
||||||
launch_conference_thread(conference);
|
launch_conference_thread(conference);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
int enforce_security = !switch_channel_test_flag(channel, CF_OUTBOUND);
|
int enforce_security = switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND;
|
||||||
const char *pvar = switch_channel_get_variable(channel, "conference_enforce_security");
|
const char *pvar = switch_channel_get_variable(channel, "conference_enforce_security");
|
||||||
|
|
||||||
if (pvar) {
|
if (pvar) {
|
||||||
|
@ -5655,7 +5655,7 @@ SWITCH_STANDARD_APP(conference_function)
|
||||||
} else {
|
} else {
|
||||||
/* if we're not using "bridge:" set the conference answered flag */
|
/* if we're not using "bridge:" set the conference answered flag */
|
||||||
/* and this isn't an outbound channel, answer the call */
|
/* and this isn't an outbound channel, answer the call */
|
||||||
if (!switch_channel_test_flag(channel, CF_OUTBOUND))
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND)
|
||||||
switch_set_flag(conference, CFLAG_ANSWERED);
|
switch_set_flag(conference, CFLAG_ANSWERED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1324,7 +1324,6 @@ static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *sessi
|
||||||
caller_profile = tech_pvt->caller_profile;
|
caller_profile = tech_pvt->caller_profile;
|
||||||
caller_profile->destination_number = rdest;
|
caller_profile->destination_number = rdest;
|
||||||
|
|
||||||
switch_channel_set_flag(channel, CF_OUTBOUND);
|
|
||||||
switch_set_flag(tech_pvt, TFLAG_OUTBOUND);
|
switch_set_flag(tech_pvt, TFLAG_OUTBOUND);
|
||||||
switch_channel_set_state(channel, CS_INIT);
|
switch_channel_set_state(channel, CS_INIT);
|
||||||
gsmopen_call(tech_pvt, rdest, 30);
|
gsmopen_call(tech_pvt, rdest, 30);
|
||||||
|
|
|
@ -725,7 +725,6 @@ FSH323Connection::FSH323Connection(FSH323EndPoint& endpoint, H323Transport* tran
|
||||||
name += outbound_profile->destination_number;
|
name += outbound_profile->destination_number;
|
||||||
switch_channel_set_name(m_fsChannel, name);
|
switch_channel_set_name(m_fsChannel, name);
|
||||||
|
|
||||||
switch_channel_set_flag(m_fsChannel, CF_OUTBOUND);
|
|
||||||
switch_channel_set_state(m_fsChannel, CS_INIT);
|
switch_channel_set_state(m_fsChannel, CS_INIT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1508,7 +1507,7 @@ switch_status_t FSH323Connection::receive_message(switch_core_session_message_t
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case SWITCH_MESSAGE_INDICATE_ANSWER: {
|
case SWITCH_MESSAGE_INDICATE_ANSWER: {
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
AnsweringCall(H323Connection::AnswerCallNow);
|
AnsweringCall(H323Connection::AnswerCallNow);
|
||||||
|
|
|
@ -868,7 +868,6 @@ switch_status_t Board::KhompPvt::justStart(switch_caller_profile_t *profile)
|
||||||
_caller_profile = switch_caller_profile_clone(_session, profile);
|
_caller_profile = switch_caller_profile_clone(_session, profile);
|
||||||
switch_channel_set_caller_profile(channel, _caller_profile);
|
switch_channel_set_caller_profile(channel, _caller_profile);
|
||||||
|
|
||||||
switch_channel_set_flag(channel, CF_OUTBOUND);
|
|
||||||
switch_channel_set_state(channel, CS_INIT);
|
switch_channel_set_state(channel, CS_INIT);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
|
|
@ -580,7 +580,6 @@ FSConnection::FSConnection(OpalCall & call, FSEndPoint & endpoint, void* userDat
|
||||||
name += outbound_profile->destination_number;
|
name += outbound_profile->destination_number;
|
||||||
switch_channel_set_name(m_fsChannel, name);
|
switch_channel_set_name(m_fsChannel, name);
|
||||||
|
|
||||||
switch_channel_set_flag(m_fsChannel, CF_OUTBOUND);
|
|
||||||
switch_channel_set_state(m_fsChannel, CS_INIT);
|
switch_channel_set_state(m_fsChannel, CS_INIT);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -966,7 +965,7 @@ switch_status_t FSConnection::receive_message(switch_core_session_message_t *msg
|
||||||
It would only happen if someone called switch_channel_answer() instead of switch_channel_mark_answered() on an outbound call.
|
It would only happen if someone called switch_channel_answer() instead of switch_channel_mark_answered() on an outbound call.
|
||||||
it should not do anything if someone does it by accident somewhere hense this in both cases:
|
it should not do anything if someone does it by accident somewhere hense this in both cases:
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1025,7 +1024,7 @@ switch_status_t FSConnection::receive_message(switch_core_session_message_t *msg
|
||||||
{
|
{
|
||||||
int fixed = 0;
|
int fixed = 0;
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
return SWITCH_STATUS_FALSE;
|
return SWITCH_STATUS_FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1080,8 +1080,6 @@ switch_call_cause_t channel_outgoing_channel(switch_core_session_t *session, swi
|
||||||
switch_channel_set_caller_profile(nchannel, caller_profile);
|
switch_channel_set_caller_profile(nchannel, caller_profile);
|
||||||
tech_pvt->caller_profile = caller_profile;
|
tech_pvt->caller_profile = caller_profile;
|
||||||
|
|
||||||
switch_channel_set_flag(nchannel, CF_OUTBOUND);
|
|
||||||
|
|
||||||
if ((sql = switch_mprintf(
|
if ((sql = switch_mprintf(
|
||||||
"INSERT INTO skinny_active_lines "
|
"INSERT INTO skinny_active_lines "
|
||||||
"(device_name, device_instance, line_instance, channel_uuid, call_id, call_state) "
|
"(device_name, device_instance, line_instance, channel_uuid, call_id, call_state) "
|
||||||
|
|
|
@ -343,7 +343,7 @@ switch_status_t skinny_session_send_call_info(switch_core_session_t *session, li
|
||||||
zstr((called_party_number = switch_channel_get_variable(channel, "destination_number")))) {
|
zstr((called_party_number = switch_channel_get_variable(channel, "destination_number")))) {
|
||||||
called_party_number = "0000000000";
|
called_party_number = "0000000000";
|
||||||
}
|
}
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
call_type = SKINNY_INBOUND_CALL;
|
call_type = SKINNY_INBOUND_CALL;
|
||||||
} else {
|
} else {
|
||||||
call_type = SKINNY_OUTBOUND_CALL;
|
call_type = SKINNY_OUTBOUND_CALL;
|
||||||
|
@ -1674,7 +1674,7 @@ switch_status_t skinny_handle_open_receive_channel_ack_message(listener_t *liste
|
||||||
);
|
);
|
||||||
|
|
||||||
switch_set_flag_locked(tech_pvt, TFLAG_IO);
|
switch_set_flag_locked(tech_pvt, TFLAG_IO);
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
switch_channel_mark_answered(channel);
|
switch_channel_mark_answered(channel);
|
||||||
}
|
}
|
||||||
if (switch_channel_test_flag(channel, CF_HOLD)) {
|
if (switch_channel_test_flag(channel, CF_HOLD)) {
|
||||||
|
|
|
@ -1364,7 +1364,6 @@ static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *sessi
|
||||||
caller_profile = tech_pvt->caller_profile;
|
caller_profile = tech_pvt->caller_profile;
|
||||||
caller_profile->destination_number = rdest;
|
caller_profile->destination_number = rdest;
|
||||||
|
|
||||||
switch_channel_set_flag(channel, CF_OUTBOUND);
|
|
||||||
switch_mutex_lock(tech_pvt->flag_mutex);
|
switch_mutex_lock(tech_pvt->flag_mutex);
|
||||||
switch_set_flag(tech_pvt, TFLAG_OUTBOUND);
|
switch_set_flag(tech_pvt, TFLAG_OUTBOUND);
|
||||||
switch_mutex_unlock(tech_pvt->flag_mutex);
|
switch_mutex_unlock(tech_pvt->flag_mutex);
|
||||||
|
|
|
@ -508,7 +508,7 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session)
|
||||||
TAG_IF(!zstr(bye_headers), SIPTAG_HEADER_STR(bye_headers)), TAG_END());
|
TAG_IF(!zstr(bye_headers), SIPTAG_HEADER_STR(bye_headers)), TAG_END());
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Sending CANCEL to %s\n", switch_channel_get_name(channel));
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Sending CANCEL to %s\n", switch_channel_get_name(channel));
|
||||||
if (!tech_pvt->got_bye) {
|
if (!tech_pvt->got_bye) {
|
||||||
switch_channel_set_variable(channel, "sip_hangup_disposition", "send_cancel");
|
switch_channel_set_variable(channel, "sip_hangup_disposition", "send_cancel");
|
||||||
|
@ -573,7 +573,7 @@ static switch_status_t sofia_answer_channel(switch_core_session_t *session)
|
||||||
char *sticky = NULL;
|
char *sticky = NULL;
|
||||||
const char *call_info = switch_channel_get_variable(channel, "presence_call_info_full");
|
const char *call_info = switch_channel_get_variable(channel, "presence_call_info_full");
|
||||||
|
|
||||||
if (sofia_test_flag(tech_pvt, TFLAG_ANS) || switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (sofia_test_flag(tech_pvt, TFLAG_ANS) || switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -653,7 +653,7 @@ static switch_status_t sofia_answer_channel(switch_core_session_t *session)
|
||||||
switch_channel_clear_flag(channel, CF_PROXY_MODE);
|
switch_channel_clear_flag(channel, CF_PROXY_MODE);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
||||||
tech_pvt->num_codecs = 0;
|
tech_pvt->num_codecs = 0;
|
||||||
sofia_glue_tech_prepare_codecs(tech_pvt);
|
sofia_glue_tech_prepare_codecs(tech_pvt);
|
||||||
|
@ -1683,7 +1683,7 @@ static switch_status_t sofia_receive_message(switch_core_session_t *session, swi
|
||||||
sofia_glue_tech_set_local_sdp(tech_pvt, NULL, SWITCH_FALSE);
|
sofia_glue_tech_set_local_sdp(tech_pvt, NULL, SWITCH_FALSE);
|
||||||
|
|
||||||
if (!(switch_channel_test_flag(channel, CF_ANSWERED) || switch_channel_test_flag(channel, CF_EARLY_MEDIA))) {
|
if (!(switch_channel_test_flag(channel, CF_ANSWERED) || switch_channel_test_flag(channel, CF_EARLY_MEDIA))) {
|
||||||
if (!switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
||||||
|
|
||||||
tech_pvt->num_codecs = 0;
|
tech_pvt->num_codecs = 0;
|
||||||
|
@ -2198,7 +2198,7 @@ static switch_status_t sofia_receive_message(switch_core_session_t *session, swi
|
||||||
} else {
|
} else {
|
||||||
if (sofia_test_flag(tech_pvt, TFLAG_LATE_NEGOTIATION) || !tech_pvt->iananame) {
|
if (sofia_test_flag(tech_pvt, TFLAG_LATE_NEGOTIATION) || !tech_pvt->iananame) {
|
||||||
sofia_clear_flag_locked(tech_pvt, TFLAG_LATE_NEGOTIATION);
|
sofia_clear_flag_locked(tech_pvt, TFLAG_LATE_NEGOTIATION);
|
||||||
if (!switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
||||||
|
|
||||||
tech_pvt->num_codecs = 0;
|
tech_pvt->num_codecs = 0;
|
||||||
|
|
|
@ -357,7 +357,7 @@ void sofia_handle_sip_i_notify(switch_core_session_t *session, int status,
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
switch_channel_answer(channel);
|
switch_channel_answer(channel);
|
||||||
switch_channel_set_variable(channel, "auto_answer_destination", switch_channel_get_variable(channel, "destination_number"));
|
switch_channel_set_variable(channel, "auto_answer_destination", switch_channel_get_variable(channel, "destination_number"));
|
||||||
switch_ivr_session_transfer(session, "auto_answer", NULL, NULL);
|
switch_ivr_session_transfer(session, "auto_answer", NULL, NULL);
|
||||||
|
@ -4114,7 +4114,7 @@ static void sofia_handle_sip_r_invite(switch_core_session_t *session, int status
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (channel && sip && (status == 300 || status == 301 || status == 302 || status == 305) && switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (channel && sip && (status == 300 || status == 301 || status == 302 || status == 305) && switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
sip_contact_t *p_contact = sip->sip_contact;
|
sip_contact_t *p_contact = sip->sip_contact;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
char var_name[80];
|
char var_name[80];
|
||||||
|
@ -4645,7 +4645,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
status = 183;
|
status = 183;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (channel && (status == 180 || status == 183) && switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (channel && (status == 180 || status == 183) && switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
const char *val;
|
const char *val;
|
||||||
if ((val = switch_channel_get_variable(channel, "sip_auto_answer")) && switch_true(val)) {
|
if ((val = switch_channel_get_variable(channel, "sip_auto_answer")) && switch_true(val)) {
|
||||||
nua_notify(nh, NUTAG_NEWSUB(1), NUTAG_SUBSTATE(nua_substate_active), SIPTAG_EVENT_STR("talk"), TAG_END());
|
nua_notify(nh, NUTAG_NEWSUB(1), NUTAG_SUBSTATE(nua_substate_active), SIPTAG_EVENT_STR("talk"), TAG_END());
|
||||||
|
@ -4692,7 +4692,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
|
|
||||||
if (r_sdp) {
|
if (r_sdp) {
|
||||||
if (switch_channel_test_flag(channel, CF_PROXY_MODE) || switch_channel_test_flag(channel, CF_PROXY_MEDIA)) {
|
if (switch_channel_test_flag(channel, CF_PROXY_MODE) || switch_channel_test_flag(channel, CF_PROXY_MEDIA)) {
|
||||||
if (switch_channel_test_flag(channel, CF_PROXY_MEDIA) && !switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (switch_channel_test_flag(channel, CF_PROXY_MEDIA) && switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
switch_channel_set_variable(channel, SWITCH_ENDPOINT_DISPOSITION_VARIABLE, "PROXY MEDIA");
|
switch_channel_set_variable(channel, SWITCH_ENDPOINT_DISPOSITION_VARIABLE, "PROXY MEDIA");
|
||||||
}
|
}
|
||||||
sofia_set_flag_locked(tech_pvt, TFLAG_EARLY_MEDIA);
|
sofia_set_flag_locked(tech_pvt, TFLAG_EARLY_MEDIA);
|
||||||
|
@ -4715,7 +4715,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
}
|
}
|
||||||
goto done;
|
goto done;
|
||||||
} else {
|
} else {
|
||||||
if (sofia_test_flag(tech_pvt, TFLAG_LATE_NEGOTIATION) && !switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (sofia_test_flag(tech_pvt, TFLAG_LATE_NEGOTIATION) && switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
switch_channel_set_variable(channel, SWITCH_ENDPOINT_DISPOSITION_VARIABLE, "DELAYED NEGOTIATION");
|
switch_channel_set_variable(channel, SWITCH_ENDPOINT_DISPOSITION_VARIABLE, "DELAYED NEGOTIATION");
|
||||||
} else {
|
} else {
|
||||||
if (sofia_glue_tech_media(tech_pvt, (char *) r_sdp) != SWITCH_STATUS_SUCCESS) {
|
if (sofia_glue_tech_media(tech_pvt, (char *) r_sdp) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
@ -4910,7 +4910,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
sofia_glue_tech_set_local_sdp(tech_pvt, NULL, SWITCH_FALSE);
|
sofia_glue_tech_set_local_sdp(tech_pvt, NULL, SWITCH_FALSE);
|
||||||
|
|
||||||
if (!switch_channel_media_ready(channel)) {
|
if (!switch_channel_media_ready(channel)) {
|
||||||
if (!switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
//const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
//const char *r_sdp = switch_channel_get_variable(channel, SWITCH_R_SDP_VARIABLE);
|
||||||
|
|
||||||
tech_pvt->num_codecs = 0;
|
tech_pvt->num_codecs = 0;
|
||||||
|
|
|
@ -4687,8 +4687,8 @@ void sofia_glue_pass_sdp(private_object_t *tech_pvt, char *sdp)
|
||||||
switch_channel_set_variable(other_channel, SWITCH_B_SDP_VARIABLE, sdp);
|
switch_channel_set_variable(other_channel, SWITCH_B_SDP_VARIABLE, sdp);
|
||||||
|
|
||||||
if (!sofia_test_flag(tech_pvt, TFLAG_CHANGE_MEDIA) && !sofia_test_flag(tech_pvt, TFLAG_RECOVERING) &&
|
if (!sofia_test_flag(tech_pvt, TFLAG_CHANGE_MEDIA) && !sofia_test_flag(tech_pvt, TFLAG_RECOVERING) &&
|
||||||
(switch_channel_test_flag(other_channel, CF_OUTBOUND) &&
|
(switch_channel_direction(other_channel) == SWITCH_CALL_DIRECTION_OUTBOUND &&
|
||||||
switch_channel_test_flag(tech_pvt->channel, CF_OUTBOUND) && switch_channel_test_flag(tech_pvt->channel, CF_PROXY_MODE))) {
|
switch_channel_direction(tech_pvt->channel) == SWITCH_CALL_DIRECTION_OUTBOUND && switch_channel_test_flag(tech_pvt->channel, CF_PROXY_MODE))) {
|
||||||
switch_ivr_nomedia(val, SMF_FORCE);
|
switch_ivr_nomedia(val, SMF_FORCE);
|
||||||
sofia_set_flag_locked(tech_pvt, TFLAG_CHANGE_MEDIA);
|
sofia_set_flag_locked(tech_pvt, TFLAG_CHANGE_MEDIA);
|
||||||
}
|
}
|
||||||
|
|
|
@ -2622,7 +2622,7 @@ SWITCH_DECLARE(switch_status_t) switch_channel_perform_pre_answer(switch_channel
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
msg.message_id = SWITCH_MESSAGE_INDICATE_PROGRESS;
|
msg.message_id = SWITCH_MESSAGE_INDICATE_PROGRESS;
|
||||||
msg.from = channel->name;
|
msg.from = channel->name;
|
||||||
status = switch_core_session_perform_receive_message(channel->session, &msg, file, func, line);
|
status = switch_core_session_perform_receive_message(channel->session, &msg, file, func, line);
|
||||||
|
@ -2657,7 +2657,7 @@ SWITCH_DECLARE(switch_status_t) switch_channel_perform_ring_ready_value(switch_c
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
msg.message_id = SWITCH_MESSAGE_INDICATE_RINGING;
|
msg.message_id = SWITCH_MESSAGE_INDICATE_RINGING;
|
||||||
msg.from = channel->name;
|
msg.from = channel->name;
|
||||||
msg.numeric_arg = rv;
|
msg.numeric_arg = rv;
|
||||||
|
@ -2800,7 +2800,7 @@ SWITCH_DECLARE(switch_status_t) switch_channel_perform_answer(switch_channel_t *
|
||||||
|
|
||||||
switch_assert(channel != NULL);
|
switch_assert(channel != NULL);
|
||||||
|
|
||||||
if (switch_channel_test_flag(channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
return SWITCH_STATUS_SUCCESS;
|
return SWITCH_STATUS_SUCCESS;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -124,7 +124,7 @@ static void switch_core_standard_on_routing(switch_core_session_t *session)
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!count) {
|
if (!count) {
|
||||||
if (switch_channel_test_flag(session->channel, CF_OUTBOUND)) {
|
if (switch_channel_direction(session->channel) == SWITCH_CALL_DIRECTION_OUTBOUND) {
|
||||||
if (switch_channel_test_flag(session->channel, CF_ANSWERED)) {
|
if (switch_channel_test_flag(session->channel, CF_ANSWERED)) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG,
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG,
|
||||||
"No Dialplan on answered channel, changing state to HANGUP\n");
|
"No Dialplan on answered channel, changing state to HANGUP\n");
|
||||||
|
|
|
@ -1206,7 +1206,7 @@ SWITCH_DECLARE(void) bridge(CoreSession &session_a, CoreSession &session_b)
|
||||||
|
|
||||||
if (switch_channel_ready(channel_a) && switch_channel_ready(channel_b)) {
|
if (switch_channel_ready(channel_a) && switch_channel_ready(channel_b)) {
|
||||||
session_a.begin_allow_threads();
|
session_a.begin_allow_threads();
|
||||||
if (!switch_channel_test_flag(channel_a, CF_OUTBOUND) && !switch_channel_media_ready(channel_a)) {
|
if (switch_channel_direction(channel_a) == SWITCH_CALL_DIRECTION_INBOUND && !switch_channel_media_ready(channel_a)) {
|
||||||
switch_channel_pre_answer(channel_a);
|
switch_channel_pre_answer(channel_a);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -140,7 +140,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_sleep(switch_core_session_t *session,
|
||||||
const char *var;
|
const char *var;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
if (!switch_channel_test_flag(channel, CF_OUTBOUND) && !switch_channel_test_flag(channel, CF_PROXY_MODE) &&
|
if (switch_channel_direction(channel) == SWITCH_CALL_DIRECTION_INBOUND && !switch_channel_test_flag(channel, CF_PROXY_MODE) &&
|
||||||
!switch_channel_media_ready(channel) && !switch_channel_test_flag(channel, CF_SERVICE)) {
|
!switch_channel_media_ready(channel) && !switch_channel_test_flag(channel, CF_SERVICE)) {
|
||||||
if ((status = switch_channel_pre_answer(channel)) != SWITCH_STATUS_SUCCESS) {
|
if ((status = switch_channel_pre_answer(channel)) != SWITCH_STATUS_SUCCESS) {
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "Cannot establish media.\n");
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "Cannot establish media.\n");
|
||||||
|
|
|
@ -435,8 +435,8 @@ static void *audio_bridge_thread(switch_thread_t *thread, void *obj)
|
||||||
switch_channel_t *un = ans_a ? chan_b : chan_a;
|
switch_channel_t *un = ans_a ? chan_b : chan_a;
|
||||||
switch_channel_t *a = un == chan_b ? chan_a : chan_b;
|
switch_channel_t *a = un == chan_b ? chan_a : chan_b;
|
||||||
|
|
||||||
if (!switch_channel_test_flag(un, CF_OUTBOUND)) {
|
if (switch_channel_direction(un) == SWITCH_CALL_DIRECTION_INBOUND) {
|
||||||
if (switch_channel_test_flag(a, CF_OUTBOUND) || (un == chan_a && !originator)) {
|
if (switch_channel_direction(a) == SWITCH_CALL_DIRECTION_OUTBOUND || (un == chan_a && !originator)) {
|
||||||
switch_channel_pass_callee_id(a, un);
|
switch_channel_pass_callee_id(a, un);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue