diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.c b/src/mod/endpoints/mod_sofia/mod_sofia.c index 894921a0db..6dc6e90f55 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.c +++ b/src/mod/endpoints/mod_sofia/mod_sofia.c @@ -315,6 +315,9 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session) } if (switch_test_flag(tech_pvt, TFLAG_ANS)) { + if (!tech_pvt->got_bye) { + switch_channel_set_variable(channel, "sip_hangup_disposition", "send_bye"); + } switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Sending BYE to %s\n", switch_channel_get_name(channel)); nua_bye(tech_pvt->nh, SIPTAG_REASON_STR(reason), @@ -323,6 +326,9 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session) } else { if (switch_test_flag(tech_pvt, TFLAG_OUTBOUND)) { switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Sending CANCEL to %s\n", switch_channel_get_name(channel)); + if (!tech_pvt->got_bye) { + switch_channel_set_variable(channel, "sip_hangup_disposition", "send_cancel"); + } nua_cancel(tech_pvt->nh, SIPTAG_REASON_STR(reason), TAG_IF(!switch_strlen_zero(bye_headers), SIPTAG_HEADER_STR(bye_headers)), @@ -330,6 +336,9 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session) TAG_END()); } else { switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Responding to INVITE with: %d\n", sip_cause); + if (!tech_pvt->got_bye) { + switch_channel_set_variable(channel, "sip_hangup_disposition", "send_refuse"); + } nua_respond(tech_pvt->nh, sip_cause, sip_status_phrase(sip_cause), SIPTAG_REASON_STR(reason), TAG_IF(!switch_strlen_zero(bye_headers), SIPTAG_HEADER_STR(bye_headers)), diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.h b/src/mod/endpoints/mod_sofia/mod_sofia.h index 1edccedf50..8c88d1ed07 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.h +++ b/src/mod/endpoints/mod_sofia/mod_sofia.h @@ -474,6 +474,7 @@ struct private_object { int q850_cause; char *remote_ip; int remote_port; + int got_bye; }; struct callback_t { diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index ba95099b7c..118742d51a 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -122,16 +122,16 @@ void sofia_handle_sip_i_bye(switch_core_session_t *session, int status, { const char *tmp; switch_channel_t *channel; + private_object_t *tech_pvt; if (!session) return; channel = switch_core_session_get_channel(session); - + tech_pvt = switch_core_session_get_private(session); if (sip->sip_reason && sip->sip_reason->re_protocol && (!strcasecmp(sip->sip_reason->re_protocol, "Q.850") || !strcasecmp(sip->sip_reason->re_protocol, "FreeSWITCH")) && sip->sip_reason->re_cause) { - private_object_t *tech_pvt = switch_core_session_get_private(session); tech_pvt->q850_cause = atoi(sip->sip_reason->re_cause); } @@ -150,7 +150,10 @@ void sofia_handle_sip_i_bye(switch_core_session_t *session, int status, if ((tmp = sofia_glue_get_unknown_header(sip, "P-RTP-Stat"))) { switch_channel_set_variable(channel, "sip_p_rtp_stat", tmp); } - + + tech_pvt->got_bye = 1; + switch_channel_set_variable(channel, "sip_hangup_disposition", "recv_bye"); + return; }