[Freeswitch-svn] [commit] r8062 - freeswitch/trunk/src/mod/endpoints/mod_sofia
Freeswitch SVN
mikej at freeswitch.org
Wed Apr 9 12:27:02 EDT 2008
Author: mikej
Date: Wed Apr 9 12:27:01 2008
New Revision: 8062
Modified:
freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c
Log:
fix hung channels when using respond app with 1xx or 2xx responses or on re-invite in proxy/bypass media with 1xx and 2xx responses
Modified: freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c
==============================================================================
--- freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c (original)
+++ freeswitch/trunk/src/mod/endpoints/mod_sofia/mod_sofia.c Wed Apr 9 12:27:01 2008
@@ -948,12 +948,9 @@
}
if (!reason && code != 407) {
- reason = "Call Refused";
- if (!reason) {
- reason = sip_status_phrase(code);
- if (switch_strlen_zero(reason)) {
- reason = "Because";
- }
+ reason = sip_status_phrase(code);
+ if (switch_strlen_zero(reason)) {
+ reason = "Because";
}
}
@@ -985,7 +982,9 @@
nua_respond(tech_pvt->nh, code, reason, TAG_IF(to_uri, SIPTAG_CONTACT_STR(to_uri)),
SIPTAG_SUPPORTED_STR(NULL), SIPTAG_ACCEPT_STR(NULL),
TAG_IF(!switch_strlen_zero(max_forwards), SIPTAG_MAX_FORWARDS_STR(max_forwards)), TAG_END());
- switch_set_flag_locked(tech_pvt, TFLAG_BYE);
+ if (!switch_channel_test_flag(channel, CF_ANSWERED)) {
+ switch_set_flag_locked(tech_pvt, TFLAG_BYE);
+ }
} else {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_DEBUG, "Responding with %d %s\n", code, reason);
@@ -1005,7 +1004,9 @@
} else {
nua_respond(tech_pvt->nh, code, reason, SIPTAG_CONTACT_STR(tech_pvt->reply_contact), TAG_END());
}
- switch_set_flag_locked(tech_pvt, TFLAG_BYE);
+ if (!switch_channel_test_flag(channel, CF_ANSWERED) && code >= 300) {
+ switch_set_flag_locked(tech_pvt, TFLAG_BYE);
+ }
}
}
More information about the Freeswitch-svn
mailing list