omfg
git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@15255 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
parent
9d6bf97b09
commit
dfafd6988e
|
@ -3546,6 +3546,8 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
NUTAG_ANSWER_SENT_REF(answer_sent),
|
NUTAG_ANSWER_SENT_REF(answer_sent),
|
||||||
SIPTAG_REPLACES_STR_REF(replaces_str), SOATAG_LOCAL_SDP_STR_REF(l_sdp), SOATAG_REMOTE_SDP_STR_REF(r_sdp), TAG_END());
|
SIPTAG_REPLACES_STR_REF(replaces_str), SOATAG_LOCAL_SDP_STR_REF(l_sdp), SOATAG_REMOTE_SDP_STR_REF(r_sdp), TAG_END());
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
if (ss_state == nua_callstate_terminated) {
|
if (ss_state == nua_callstate_terminated) {
|
||||||
|
|
||||||
if ((status == 300 || status == 302 || status == 305) && session) {
|
if ((status == 300 || status == 302 || status == 305) && session) {
|
||||||
|
@ -3576,6 +3578,13 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ((switch_channel_test_flag(channel, CF_EARLY_MEDIA) || switch_channel_test_flag(channel, CF_ANSWERED)) && status < 200) {
|
||||||
|
/* Must you send 180 after 183 w/sdp ? sheesh */
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Channel %s skipping state [%s][%d]\n",
|
||||||
|
switch_channel_get_name(channel), nua_callstate_name(ss_state), status);
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
|
||||||
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Channel %s entering state [%s][%d]\n",
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Channel %s entering state [%s][%d]\n",
|
||||||
switch_channel_get_name(channel), nua_callstate_name(ss_state), status);
|
switch_channel_get_name(channel), nua_callstate_name(ss_state), status);
|
||||||
|
|
||||||
|
@ -3917,7 +3926,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
goto done;
|
goto done;
|
||||||
} else {
|
} else {
|
||||||
sofia_set_flag_locked(tech_pvt, TFLAG_REINVITE);
|
sofia_set_flag_locked(tech_pvt, TFLAG_REINVITE);
|
||||||
|
|
||||||
if (tech_pvt->num_codecs) {
|
if (tech_pvt->num_codecs) {
|
||||||
if ((parser = sdp_parse(NULL, r_sdp, (int) strlen(r_sdp), 0))) {
|
if ((parser = sdp_parse(NULL, r_sdp, (int) strlen(r_sdp), 0))) {
|
||||||
if ((sdp = sdp_session(parser))) {
|
if ((sdp = sdp_session(parser))) {
|
||||||
|
@ -3945,6 +3954,7 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (is_ok) {
|
if (is_ok) {
|
||||||
if (tech_pvt->local_crypto_key) {
|
if (tech_pvt->local_crypto_key) {
|
||||||
sofia_glue_set_local_sdp(tech_pvt, NULL, 0, NULL, 0);
|
sofia_glue_set_local_sdp(tech_pvt, NULL, 0, NULL, 0);
|
||||||
|
@ -3968,8 +3978,40 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status,
|
||||||
break;
|
break;
|
||||||
case nua_callstate_ready:
|
case nua_callstate_ready:
|
||||||
if (r_sdp && !is_dup_sdp && switch_rtp_ready(tech_pvt->rtp_session)) {
|
if (r_sdp && !is_dup_sdp && switch_rtp_ready(tech_pvt->rtp_session)) {
|
||||||
ss_state = nua_callstate_completed;
|
/* sdp changed since 18X w sdp, we're supposed to ignore it but we, of course, were pressured into supporting it */
|
||||||
goto state_process;
|
sdp_parser_t *parser;
|
||||||
|
sdp_session_t *sdp;
|
||||||
|
uint8_t match = 0;
|
||||||
|
|
||||||
|
sofia_set_flag_locked(tech_pvt, TFLAG_REINVITE);
|
||||||
|
|
||||||
|
if (tech_pvt->num_codecs) {
|
||||||
|
if ((parser = sdp_parse(NULL, r_sdp, (int) strlen(r_sdp), 0))) {
|
||||||
|
if ((sdp = sdp_session(parser))) {
|
||||||
|
match = sofia_glue_negotiate_sdp(session, sdp);
|
||||||
|
}
|
||||||
|
sdp_parser_free(parser);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (match) {
|
||||||
|
if (sofia_glue_tech_choose_port(tech_pvt, 0) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
sofia_glue_set_local_sdp(tech_pvt, NULL, 0, NULL, 0);
|
||||||
|
|
||||||
|
if (sofia_glue_activate_rtp(tech_pvt, 0) != SWITCH_STATUS_SUCCESS) {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "RTP Error!\n");
|
||||||
|
goto done;
|
||||||
|
switch_channel_hangup(channel, SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER);
|
||||||
|
} else {
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_DEBUG, "Processing updated SDP\n");
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
sofia_clear_flag_locked(tech_pvt, TFLAG_REINVITE);
|
||||||
|
switch_log_printf(SWITCH_CHANNEL_SESSION_LOG(session), SWITCH_LOG_ERROR, "Codec Error!\n");
|
||||||
|
goto done;
|
||||||
|
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (r_sdp && sofia_test_flag(tech_pvt, TFLAG_NOSDP_REINVITE)) {
|
if (r_sdp && sofia_test_flag(tech_pvt, TFLAG_NOSDP_REINVITE)) {
|
||||||
|
|
Loading…
Reference in New Issue