nevermind contact_user param make it extension-in-contact for rare cases when provider makes you say a certian contact user 'LAME'

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@12511 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2009-03-07 16:03:44 +00:00
parent 1d258086a0
commit 80159461d7
1 changed files with 5 additions and 6 deletions

View File

@ -1075,7 +1075,7 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
if ((gateway = switch_core_alloc(profile->pool, sizeof(*gateway)))) { if ((gateway = switch_core_alloc(profile->pool, sizeof(*gateway)))) {
const char *sipip, *format; const char *sipip, *format;
switch_uuid_t uuid; switch_uuid_t uuid;
uint32_t ping_freq = 0; uint32_t ping_freq = 0, extension_in_contact = 0;
char *register_str = "true", *scheme = "Digest", char *register_str = "true", *scheme = "Digest",
*realm = NULL, *realm = NULL,
*username = NULL, *username = NULL,
@ -1085,7 +1085,6 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
*extension = NULL, *extension = NULL,
*proxy = NULL, *proxy = NULL,
*context = profile->context, *context = profile->context,
*contact_user = NULL,
*expire_seconds = "3600", *expire_seconds = "3600",
*retry_seconds = "30", *retry_seconds = "30",
*from_user = "", *from_domain = "", *register_proxy = NULL, *contact_params = NULL, *params = NULL, *register_transport = NULL; *from_user = "", *from_domain = "", *register_proxy = NULL, *contact_params = NULL, *params = NULL, *register_transport = NULL;
@ -1165,8 +1164,8 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
realm = val; realm = val;
} else if (!strcmp(var, "username")) { } else if (!strcmp(var, "username")) {
username = val; username = val;
} else if (!strcmp(var, "contact-username")) { } else if (!strcmp(var, "extension-in-contact")) {
contact_user = val; extension_in_contact = switch_true(val);
} else if (!strcmp(var, "auth-username")) { } else if (!strcmp(var, "auth-username")) {
auth_username = val; auth_username = val;
} else if (!strcmp(var, "password")) { } else if (!strcmp(var, "password")) {
@ -1297,9 +1296,9 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
gateway->register_from = switch_core_sprintf(gateway->pool, "<sip:%s@%s;transport=%s>", from_user, from_domain, register_transport); gateway->register_from = switch_core_sprintf(gateway->pool, "<sip:%s@%s;transport=%s>", from_user, from_domain, register_transport);
sipip = profile->extsipip ? profile->extsipip : profile->sipip; sipip = profile->extsipip ? profile->extsipip : profile->sipip;
if (contact_user) { if (extension_in_contact) {
format = strchr(sipip, ':') ? "<sip:%s@[%s]:%d%s>" : "<sip:%s@%s:%d%s>"; format = strchr(sipip, ':') ? "<sip:%s@[%s]:%d%s>" : "<sip:%s@%s:%d%s>";
gateway->register_contact = switch_core_sprintf(gateway->pool, format, contact_user, gateway->register_contact = switch_core_sprintf(gateway->pool, format, extension,
sipip, sipip,
sofia_glue_transport_has_tls(gateway->register_transport) ? sofia_glue_transport_has_tls(gateway->register_transport) ?
profile->tls_sip_port : profile->sip_port, params); profile->tls_sip_port : profile->sip_port, params);