From 638cbf16ccf1403db0c39104d18fc5d8ea194273 Mon Sep 17 00:00:00 2001 From: Brian West Date: Tue, 21 Dec 2010 19:32:54 -0600 Subject: [PATCH] Sofia madness to make crap just work --- src/mod/endpoints/mod_sofia/sofia_reg.c | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/mod/endpoints/mod_sofia/sofia_reg.c b/src/mod/endpoints/mod_sofia/sofia_reg.c index 945740eb57..961eaa3ea0 100644 --- a/src/mod/endpoints/mod_sofia/sofia_reg.c +++ b/src/mod/endpoints/mod_sofia/sofia_reg.c @@ -1065,6 +1065,7 @@ uint8_t sofia_reg_handle_register(nua_t *nua, sofia_profile_t *profile, nua_hand if (exptime && v_event && *v_event) { char *exp_var; char *allow_multireg = NULL; + int force_connectile = 0; allow_multireg = switch_event_get_header(*v_event, "sip-allow-multiple-registrations"); if (allow_multireg && switch_false(allow_multireg)) { @@ -1081,8 +1082,13 @@ uint8_t sofia_reg_handle_register(nua_t *nua, sofia_profile_t *profile, nua_hand to_user = force_user; } - if ((v_contact_str = switch_event_get_header(*v_event, "sip-force-contact"))) { - if (!strcasecmp(v_contact_str, "NDLB-connectile-dysfunction-2.0")) { + if (profile->rport_level == 3 && sip->sip_user_agent && + sip->sip_user_agent->g_string && !strncasecmp(sip->sip_user_agent->g_string, "Polycom", 7)) { + force_connectile = 1; + } + + if ((v_contact_str = switch_event_get_header(*v_event, "sip-force-contact")) || force_connectile) { + if ((!strcasecmp(v_contact_str, "NDLB-connectile-dysfunction-2.0")) || force_connectile) { char *path_encoded; size_t path_encoded_len; char my_contact_str[1024];