sort out proxy stuff SFSIP-165

git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@14263 d0543943-73ff-0310-b7d9-9358b9ac24b2
This commit is contained in:
Anthony Minessale 2009-07-16 00:46:35 +00:00
parent 23e66c8a20
commit 70a91c8f09
3 changed files with 29 additions and 8 deletions

View File

@ -2659,10 +2659,14 @@ static switch_call_cause_t sofia_outgoing_channel(switch_core_session_t *session
gateway_ptr->ob_calls++; gateway_ptr->ob_calls++;
if (!switch_strlen_zero(gateway_ptr->from_domain)) { if (!switch_strlen_zero(gateway_ptr->from_domain) && !switch_channel_get_variable(nchannel, "sip_invite_domain")) {
switch_channel_set_variable(nchannel, "sip_invite_domain", gateway_ptr->from_domain); switch_channel_set_variable(nchannel, "sip_invite_domain", gateway_ptr->from_domain);
} }
if (!switch_strlen_zero(gateway_ptr->outbound_sticky_proxy) && !switch_channel_get_variable(nchannel, "sip_route_uri")) {
switch_channel_set_variable(nchannel, "sip_route_uri", gateway_ptr->outbound_sticky_proxy);
}
if (gateway_ptr->ob_vars) { if (gateway_ptr->ob_vars) {
switch_event_header_t *hp; switch_event_header_t *hp;
for(hp = gateway_ptr->ob_vars->headers; hp; hp = hp->next) { for(hp = gateway_ptr->ob_vars->headers; hp; hp = hp->next) {

View File

@ -353,6 +353,7 @@ struct sofia_gateway {
char *register_to; char *register_to;
char *register_proxy; char *register_proxy;
char *register_sticky_proxy; char *register_sticky_proxy;
char *outbound_sticky_proxy;
char *register_context; char *register_context;
char *expires_str; char *expires_str;
char *register_url; char *register_url;

View File

@ -1205,7 +1205,7 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
*context = profile->context, *context = profile->context,
*expire_seconds = "3600", *expire_seconds = "3600",
*retry_seconds = "30", *retry_seconds = "30",
*from_user = "", *from_domain = "", *register_proxy = NULL, *contact_host = NULL, *from_user = "", *from_domain = "", *outbound_proxy = NULL, *register_proxy = NULL, *contact_host = NULL,
*contact_params = NULL, *params = NULL, *register_transport = NULL; *contact_params = NULL, *params = NULL, *register_transport = NULL;
if (!context) { if (!context) {
@ -1313,6 +1313,8 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
contact_host = val; contact_host = val;
} else if (!strcmp(var, "register-proxy")) { } else if (!strcmp(var, "register-proxy")) {
register_proxy = val; register_proxy = val;
} else if (!strcmp(var, "outbound-proxy")) {
outbound_proxy = val;
} else if (!strcmp(var, "contact-params")) { } else if (!strcmp(var, "contact-params")) {
contact_params = val; contact_params = val;
} else if (!strcmp(var, "register-transport")) { } else if (!strcmp(var, "register-transport")) {
@ -1385,28 +1387,41 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
if (!switch_strlen_zero(register_proxy)) { if (!switch_strlen_zero(register_proxy)) {
if (strncasecmp(register_proxy, "sip:", 4) && strncasecmp(register_proxy, "sips:", 5)) { if (strncasecmp(register_proxy, "sip:", 4) && strncasecmp(register_proxy, "sips:", 5)) {
gateway->register_sticky_proxy = switch_core_sprintf(gateway->pool, "sip:%s", register_proxy); gateway->outbound_sticky_proxy = switch_core_sprintf(gateway->pool, "sip:%s", register_proxy);
} else { } else {
gateway->register_sticky_proxy = switch_core_strdup(gateway->pool, register_proxy); gateway->outbound_sticky_proxy = switch_core_strdup(gateway->pool, register_proxy);
}
}
if (!switch_strlen_zero(outbound_proxy)) {
if (strncasecmp(outbound_proxy, "sip:", 4) && strncasecmp(outbound_proxy, "sips:", 5)) {
gateway->register_sticky_proxy = switch_core_sprintf(gateway->pool, "sip:%s", outbound_proxy);
} else {
gateway->register_sticky_proxy = switch_core_strdup(gateway->pool, outbound_proxy);
} }
} }
gateway->retry_seconds = atoi(retry_seconds); gateway->retry_seconds = atoi(retry_seconds);
if (gateway->retry_seconds < 5) { if (gateway->retry_seconds < 5) {
switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Invalid retry-seconds of %d on gateway %s, using the value of 30 instead.\n", switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_WARNING, "Invalid retry-seconds of %d on gateway %s, using the value of 30 instead.\n",
gateway->retry_seconds, name); gateway->retry_seconds, name);
gateway->retry_seconds = 30; gateway->retry_seconds = 30;
} }
gateway->register_scheme = switch_core_strdup(gateway->pool, scheme); gateway->register_scheme = switch_core_strdup(gateway->pool, scheme);
gateway->register_context = switch_core_strdup(gateway->pool, context); gateway->register_context = switch_core_strdup(gateway->pool, context);
gateway->register_realm = switch_core_strdup(gateway->pool, realm); gateway->register_realm = switch_core_strdup(gateway->pool, realm);
gateway->register_username = switch_core_strdup(gateway->pool, username); gateway->register_username = switch_core_strdup(gateway->pool, username);
gateway->auth_username = switch_core_strdup(gateway->pool, auth_username); gateway->auth_username = switch_core_strdup(gateway->pool, auth_username);
gateway->register_password = switch_core_strdup(gateway->pool, password); gateway->register_password = switch_core_strdup(gateway->pool, password);
if (switch_true(caller_id_in_from)) { if (switch_true(caller_id_in_from)) {
sofia_set_flag(gateway, REG_FLAG_CALLERID); sofia_set_flag(gateway, REG_FLAG_CALLERID);
} }
register_transport = (char *) sofia_glue_transport2str(gateway->register_transport); register_transport = (char *) sofia_glue_transport2str(gateway->register_transport);
if (contact_params) { if (contact_params) {
if (*contact_params == ';') { if (*contact_params == ';') {
params = switch_core_sprintf(gateway->pool, "%s;transport=%s", contact_params, register_transport); params = switch_core_sprintf(gateway->pool, "%s;transport=%s", contact_params, register_transport);
@ -1421,10 +1436,11 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
gateway->from_domain = switch_core_strdup(gateway->pool, from_domain); gateway->from_domain = switch_core_strdup(gateway->pool, from_domain);
} }
gateway->register_url = switch_core_sprintf(gateway->pool, "sip:%s", from_domain ? from_domain : register_proxy ? register_proxy : proxy); gateway->register_url = switch_core_sprintf(gateway->pool, "sip:%s", proxy);
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 = contact_host ? contact_host : profile->extsipip ? profile->extsipip : profile->sipip; sipip = contact_host ? contact_host : profile->extsipip ? profile->extsipip : profile->sipip;
if (extension_in_contact) { 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, extension, gateway->register_contact = switch_core_sprintf(gateway->pool, format, extension,
@ -1438,15 +1454,15 @@ static void parse_gateways(sofia_profile_t *profile, switch_xml_t gateways_tag)
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);
} }
gateway->extension = switch_core_strdup(gateway->pool, extension);
gateway->extension = switch_core_strdup(gateway->pool, extension);
if (!strncasecmp(proxy, "sip:", 4)) { if (!strncasecmp(proxy, "sip:", 4)) {
gateway->register_proxy = switch_core_strdup(gateway->pool, proxy); gateway->register_proxy = switch_core_strdup(gateway->pool, proxy);
gateway->register_to = switch_core_sprintf(gateway->pool, "sip:%s@%s", username, from_domain); gateway->register_to = switch_core_sprintf(gateway->pool, "sip:%s@%s", username, proxy + 4);
} else { } else {
gateway->register_proxy = switch_core_sprintf(gateway->pool, "sip:%s", proxy); gateway->register_proxy = switch_core_sprintf(gateway->pool, "sip:%s", proxy);
gateway->register_to = switch_core_sprintf(gateway->pool, "sip:%s@%s", username, from_domain); gateway->register_to = switch_core_sprintf(gateway->pool, "sip:%s@%s", username, proxy);
} }
gateway->expires_str = switch_core_strdup(gateway->pool, expire_seconds); gateway->expires_str = switch_core_strdup(gateway->pool, expire_seconds);