[Freeswitch-svn] [commit] r8861 - freeswitch/trunk/src/mod/endpoints/mod_sofia
Freeswitch SVN
anthm at freeswitch.org
Fri Jun 27 17:39:00 EDT 2008
Author: anthm
Date: Fri Jun 27 17:38:59 2008
New Revision: 8861
Modified:
freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_reg.c
Log:
deal with some sips: contacts
Modified: freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_reg.c
==============================================================================
--- freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_reg.c (original)
+++ freeswitch/trunk/src/mod/endpoints/mod_sofia/sofia_reg.c Fri Jun 27 17:38:59 2008
@@ -439,6 +439,11 @@
const char *contact_host = contact->m_url->url_host;
char *path_encoded = NULL;
int path_encoded_len = 0;
+ const char *proto = "sip";
+
+ if (sip->sip_contact->m_url->url_type == url_sips) {
+ proto = "sips";
+ }
display = contact->m_display;
@@ -475,11 +480,11 @@
}
if (contact->m_url->url_params) {
- switch_snprintf(contact_str, sizeof(contact_str), "%s <sip:%s@%s%s;%s%s%s%s>",
- display, contact->m_url->url_user, contact_host, new_port,
+ switch_snprintf(contact_str, sizeof(contact_str), "%s <%s:%s@%s%s;%s%s%s%s>",
+ display, proto, contact->m_url->url_user, contact_host, new_port,
contact->m_url->url_params, received_data, is_nat ? ";fs_nat=yes" : "", path_encoded ? path_encoded : "");
} else {
- switch_snprintf(contact_str, sizeof(contact_str), "%s <sip:%s@%s%s%s%s%s>", display, contact->m_url->url_user, contact_host, new_port,
+ switch_snprintf(contact_str, sizeof(contact_str), "%s <%s:%s@%s%s%s%s%s>", display, proto, contact->m_url->url_user, contact_host, new_port,
received_data, is_nat ? ";fs_nat=yes" : "", path_encoded ? path_encoded : "");
}
@@ -730,6 +735,7 @@
sofia_regtype_t type = REG_REGISTER;
int network_port = 0;
char *is_nat = NULL;
+ int is_tls = 0, is_tcp = 0;
get_addr(network_ip, sizeof(network_ip), &((struct sockaddr_in *) my_addrinfo->ai_addr)->sin_addr);
network_port = ntohs(((struct sockaddr_in *) msg_addrinfo(nua_current_request(nua))->ai_addr)->sin_port);
@@ -746,45 +752,59 @@
goto end;
}
- if ((profile->pflags & PFLAG_AGGRESSIVE_NAT_DETECTION)) {
- if (sip && sip->sip_via) {
- const char *port = sip->sip_via->v_port;
- const char *host = sip->sip_via->v_host;
-
- if (host && sip->sip_via->v_received) {
- is_nat = "via received";
- } else if (host && strcmp(network_ip, host)) {
- is_nat = "via host";
- } else if (port && atoi(port) != network_port) {
- is_nat = "via port";
- }
- }
+ if (switch_stristr("transport=tls", sip->sip_contact->m_url->url_params)) {
+ is_tls += 1;
}
- if (!is_nat && profile->nat_acl_count) {
- uint32_t x = 0;
- int ok = 1;
- char *last_acl = NULL;
- const char *contact_host = NULL;
+ if (sip->sip_contact->m_url->url_type == url_sips) {
+ is_tls += 2;
+ }
- if (sip && sip->sip_contact && sip->sip_contact->m_url) {
- contact_host = sip->sip_contact->m_url->url_host;
+ if (switch_stristr("transport=tcp", sip->sip_contact->m_url->url_params)) {
+ is_tcp = 1;
+ }
+
+ if (!is_tls && !is_tcp) {
+ if ((profile->pflags & PFLAG_AGGRESSIVE_NAT_DETECTION)) {
+ if (sip && sip->sip_via) {
+ const char *port = sip->sip_via->v_port;
+ const char *host = sip->sip_via->v_host;
+
+ if (host && sip->sip_via->v_received) {
+ is_nat = "via received";
+ } else if (host && strcmp(network_ip, host)) {
+ is_nat = "via host";
+ } else if (port && atoi(port) != network_port) {
+ is_nat = "via port";
+ }
+ }
}
- if (!switch_strlen_zero(contact_host)) {
- for (x = 0; x < profile->nat_acl_count; x++) {
- last_acl = profile->nat_acl[x];
- if (!(ok = switch_check_network_list_ip(contact_host, last_acl))) {
- break;
- }
+ if (!is_nat && profile->nat_acl_count) {
+ uint32_t x = 0;
+ int ok = 1;
+ char *last_acl = NULL;
+ const char *contact_host = NULL;
+
+ if (sip && sip->sip_contact && sip->sip_contact->m_url) {
+ contact_host = sip->sip_contact->m_url->url_host;
}
- if (ok) {
- is_nat = last_acl;
+ if (!switch_strlen_zero(contact_host)) {
+ for (x = 0; x < profile->nat_acl_count; x++) {
+ last_acl = profile->nat_acl[x];
+ if (!(ok = switch_check_network_list_ip(contact_host, last_acl))) {
+ break;
+ }
+ }
+
+ if (ok) {
+ is_nat = last_acl;
+ }
}
}
}
-
+
if (profile->reg_acl_count) {
uint32_t x = 0;
int ok = 1;
@@ -813,7 +833,7 @@
}
sofia_reg_handle_register(nua, profile, nh, sip, type, key, sizeof(key), &v_event, is_nat);
-
+
if (v_event) {
switch_event_fire(&v_event);
}
More information about the Freeswitch-svn
mailing list