From 5011d94020974b22b7bd4ebaa423f8a023b8faa8 Mon Sep 17 00:00:00 2001 From: Brian West Date: Sat, 2 Feb 2008 00:26:22 +0000 Subject: [PATCH] add reason git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@7488 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/mod/endpoints/mod_sofia/mod_sofia.c | 4 +++- src/mod/endpoints/mod_sofia/sofia.c | 10 +++++++++- 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/src/mod/endpoints/mod_sofia/mod_sofia.c b/src/mod/endpoints/mod_sofia/mod_sofia.c index 0537aa9445..96e786909c 100644 --- a/src/mod/endpoints/mod_sofia/mod_sofia.c +++ b/src/mod/endpoints/mod_sofia/mod_sofia.c @@ -279,8 +279,10 @@ switch_status_t sofia_on_hangup(switch_core_session_t *session) if (tech_pvt->nh && !switch_test_flag(tech_pvt, TFLAG_BYE)) { if (switch_test_flag(tech_pvt, TFLAG_ANS)) { + char reason[128] = ""; + switch_snprintf(reason, sizeof(reason), "Q.850;cause=%d;text=\"%s\"", cause, switch_channel_cause2str(cause)); switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Sending BYE to %s\n", switch_channel_get_name(channel)); - nua_bye(tech_pvt->nh, TAG_END()); + nua_bye(tech_pvt->nh, SIPTAG_REASON_STR(reason), TAG_END()); } else { if (switch_test_flag(tech_pvt, TFLAG_OUTBOUND)) { switch_call_cause_t causecode = switch_channel_get_cause(channel); diff --git a/src/mod/endpoints/mod_sofia/sofia.c b/src/mod/endpoints/mod_sofia/sofia.c index a54b61f7fb..1b00f1cfc0 100644 --- a/src/mod/endpoints/mod_sofia/sofia.c +++ b/src/mod/endpoints/mod_sofia/sofia.c @@ -1783,9 +1783,17 @@ static void sofia_handle_sip_i_state(switch_core_session_t *session, int status, if (switch_test_flag(tech_pvt, TFLAG_NOHUP)) { switch_clear_flag_locked(tech_pvt, TFLAG_NOHUP); } else { + int cause; + if (sip->sip_reason && sip->sip_reason->re_protocol && !strcasecmp(sip->sip_reason->re_protocol, "Q.850") && sip->sip_reason->re_cause) { + cause = atoi(sip->sip_reason->re_cause); + } else { + cause = sofia_glue_sip_cause_to_freeswitch(status); + } switch_snprintf(st, sizeof(st), "%d", status); switch_channel_set_variable(channel, "sip_term_status", st); - switch_channel_hangup(channel, sofia_glue_sip_cause_to_freeswitch(status)); + switch_snprintf(st, sizeof(st), "%d", cause); + switch_channel_set_variable(channel, "sip_term_cause", st); + switch_channel_hangup(channel, cause); } }