diff options
-rw-r--r-- | net/siproxd/Makefile | 2 | ||||
-rw-r--r-- | net/siproxd/distinfo | 4 | ||||
-rw-r--r-- | net/siproxd/files/patch-doc_siproxd.conf.example | 20 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_proxy.c | 218 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_register.c | 145 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_sip_utilc.c | 154 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_siproxd.c | 84 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_siproxd.h | 80 | ||||
-rw-r--r-- | net/siproxd/files/patch-src_utils.c | 60 |
9 files changed, 14 insertions, 753 deletions
diff --git a/net/siproxd/Makefile b/net/siproxd/Makefile index 20332e3ef6f..7cb8ad132e6 100644 --- a/net/siproxd/Makefile +++ b/net/siproxd/Makefile @@ -6,7 +6,7 @@ # PORTNAME= siproxd -PORTVERSION= 0.5.10 +PORTVERSION= 0.5.11 CATEGORIES= net MASTER_SITES= ${MASTER_SITE_SOURCEFORGE} MASTER_SITE_SUBDIR= siproxd diff --git a/net/siproxd/distinfo b/net/siproxd/distinfo index f85097f6bfd..d8c393a3602 100644 --- a/net/siproxd/distinfo +++ b/net/siproxd/distinfo @@ -1,2 +1,2 @@ -MD5 (siproxd-0.5.10.tar.gz) = f7c867affe6f1c6674bf174af6c9dd32 -SIZE (siproxd-0.5.10.tar.gz) = 201888 +MD5 (siproxd-0.5.11.tar.gz) = a614f60683f9ea9423573bc5d646c525 +SIZE (siproxd-0.5.11.tar.gz) = 216684 diff --git a/net/siproxd/files/patch-doc_siproxd.conf.example b/net/siproxd/files/patch-doc_siproxd.conf.example index eb3f1d7903a..82c2094eb5f 100644 --- a/net/siproxd/files/patch-doc_siproxd.conf.example +++ b/net/siproxd/files/patch-doc_siproxd.conf.example @@ -1,17 +1,17 @@ ---- doc/siproxd.conf.example.orig Thu Dec 30 12:26:17 2004 -+++ doc/siproxd.conf.example Fri Apr 8 21:02:45 2005 -@@ -9,8 +9,8 @@ - ###################################################################### - # The interface names of INBOUND and OUTBOUND interface. +--- doc/siproxd.conf.example.orig Tue Apr 19 21:00:20 2005 ++++ doc/siproxd.conf.example Thu May 5 17:35:35 2005 +@@ -17,8 +17,8 @@ + # or a hostname that resolves to that address (use a dyndns address for + # example). # -if_inbound = eth0 -if_outbound = ppp0 +if_inbound = ed0 +if_outbound = tun0 - - - ###################################################################### -@@ -70,20 +70,20 @@ + # uncomment the following line ONLY IF YOU KNOW WHAT YOU ARE DOING! + # READ THE FAQ FIRST! + #host_outbound = 1.2.3.4 +@@ -81,14 +81,14 @@ # user: uid/gid to switch to after startup # chrootjail: path to chroot to (chroot jail) user = nobody @@ -27,6 +27,8 @@ +registration_file = siproxd_registrations ###################################################################### + # Automatically save current registrations every 'n' seconds +@@ -99,7 +99,7 @@ # PID file: # Where to create the PID file. # This file holds the PID of the main thread of siproxd. diff --git a/net/siproxd/files/patch-src_proxy.c b/net/siproxd/files/patch-src_proxy.c deleted file mode 100644 index 8c9fc2f8a13..00000000000 --- a/net/siproxd/files/patch-src_proxy.c +++ /dev/null @@ -1,218 +0,0 @@ ---- src/proxy.c.orig Mon Jan 24 20:12:40 2005 -+++ src/proxy.c Sat Apr 9 16:01:02 2005 -@@ -35,7 +35,7 @@ - #include "siproxd.h" - #include "log.h" - --static char const ident[]="$Id: proxy.c,v 1.80 2005/01/24 19:12:40 hb9xar Exp $"; -+static char const ident[]="$Id: proxy.c,v 1.85 2005/03/27 16:05:16 hb9xar Exp $"; - - /* configuration storage */ - extern struct siproxd_config configuration; /* defined in siproxd.c */ -@@ -81,6 +81,7 @@ - osip_uri_t *url; - int port; - char *buffer; -+ int buflen; - osip_message_t *request; - struct sockaddr_in *from; - -@@ -516,14 +517,14 @@ - * RFC 3261, Section 16.6 step 10 - * Proxy Behavior - Forward the new request - */ -- sts = osip_message_to_str(request, &buffer); -+ sts = osip_message_to_str(request, &buffer, &buflen); - if (sts != 0) { - ERROR("proxy_request: osip_message_to_str failed"); - return STS_FAILURE; - } - - sipsock_send(sendto_addr, port, ticket->protocol, -- buffer, strlen(buffer)); -+ buffer, buflen); - osip_free (buffer); - - /* -@@ -565,6 +566,7 @@ - osip_via_t *via; - int port; - char *buffer; -+ int buflen; - osip_message_t *response; - struct sockaddr_in *from; - -@@ -669,8 +671,8 @@ - (e.g 1393xxx@proxy01.sipphone.com for calls made sipphone -> FWD) - How can we deal with this? Should I take into consideration the 'Via' - headers? This is the only clue I have, pointing to the *real* UA. -- Maybe I should put in a 'siproxd' ftag value to recognize it a header -- put in by myself -+ Maybe I should put in a 'siproxd' ftag value to recognize it as a header -+ inserted by myself - */ - if ((type == 0) && (!osip_list_eol(response->vias, 0))) { - osip_via_t *via; -@@ -910,14 +912,14 @@ - } - } - -- sts = osip_message_to_str(response, &buffer); -+ sts = osip_message_to_str(response, &buffer, &buflen); - if (sts != 0) { - ERROR("proxy_response: osip_message_to_str failed"); - return STS_FAILURE; - } - - sipsock_send(sendto_addr, port, ticket->protocol, -- buffer, strlen(buffer)); -+ buffer, buflen); - osip_free (buffer); - return STS_SUCCESS; - } -@@ -938,6 +940,7 @@ - struct in_addr map_addr, addr_sess, addr_media, outside_addr, inside_addr; - int sts; - char *bodybuff; -+ int bodybuflen; - char clen[8]; /* content length: probably never more than 7 digits !*/ - int map_port, msg_port; - int media_stream_no; -@@ -966,25 +969,31 @@ - } - } - -- sts = osip_body_to_str(body, &bodybuff); -+ sts = osip_body_to_str(body, &bodybuff, &bodybuflen); -+ if (sts != 0) { -+ ERROR("rewrite_invitation_body: unable to osip_body_to_str"); -+ } - sts = sdp_message_init(&sdp); - sts = sdp_message_parse (sdp, bodybuff); -- osip_free(bodybuff); - if (sts != 0) { - ERROR("rewrite_invitation_body: unable to sdp_message_parse body"); -+ DUMP_BUFFER(-1, bodybuff, bodybuflen); -+ osip_free(bodybuff); - sdp_message_free(sdp); - return STS_FAILURE; - } -+ osip_free(bodybuff); - - - if (configuration.debuglevel) - { /* just dump the buffer */ - char *tmp, *tmp2; -+ int tmplen; - sts = osip_message_get_body(mymsg, 0, &body); -- sts = osip_body_to_str(body, &tmp); -+ sts = osip_body_to_str(body, &tmp, &tmplen); - osip_content_length_to_str(mymsg->content_length, &tmp2); - DEBUG("Body before rewrite (clen=%s, strlen=%i):\n%s\n----", -- tmp2, strlen(tmp), tmp); -+ tmp2, tmplen, tmp); - osip_free(tmp); - osip_free(tmp2); - } -@@ -995,22 +1004,16 @@ - */ - - /* get outbound address */ -- if (get_ip_by_ifname(configuration.outbound_if, &outside_addr) != -- STS_SUCCESS) { -- ERROR("can't find outbound interface %s - configuration error?", -- configuration.outbound_if); -+ if (get_interface_ip(IF_OUTBOUND, &outside_addr) != STS_SUCCESS) { - sdp_message_free(sdp); - return STS_FAILURE; - } - - /* get inbound address */ -- if (get_ip_by_ifname(configuration.inbound_if, &inside_addr) != -- STS_SUCCESS) { -- ERROR("can't find inbound interface %s - configuration error?", -- configuration.inbound_if); -+ if (get_interface_ip(IF_INBOUND, &inside_addr) != STS_SUCCESS) { - sdp_message_free(sdp); -- return STS_FAILURE; -- } -+ return STS_FAILURE; -+ } - - /* figure out what address to use for RTP masquerading */ - if (MSG_IS_REQUEST(mymsg)) { -@@ -1081,7 +1084,6 @@ - * Rewrite - * an IP address of 0.0.0.0 means *MUTE*, don't rewrite such - */ -- /*&&&& should use gethostbyname here */ - if (strcmp(sdp->c_connection->c_addr, "0.0.0.0") != 0) { - osip_free(sdp->c_connection->c_addr); - sdp->c_connection->c_addr=osip_malloc(HOSTNAME_SIZE); -@@ -1126,7 +1128,6 @@ - have_c_media=0; - sdp_conn=sdp_message_connection_get(sdp, media_stream_no, 0); - if (sdp_conn && sdp_conn->c_addr) { -- /*&&&& should use gethostbyname here as well */ - if (strcmp(sdp_conn->c_addr, "0.0.0.0") != 0) { - sts = get_ip_by_host(sdp_conn->c_addr, &addr_media); - have_c_media=1; -@@ -1170,6 +1171,19 @@ - memcpy(&addr_media, &addr_sess, sizeof(addr_sess)); - } - -+ /* -+ * Am I running in front of the routing device? Then I cannot -+ * use the external IP to bind a listen socket to, so force -+ * the use of my inbound IP for listening. -+ */ -+ if ((rtp_direction == DIR_INCOMING) && -+ (configuration.outbound_host) && -+ (strcmp(configuration.outbound_host, "")!=0)) { -+ DEBUGC(DBCLASS_PROXY, "proxy_rewrite_invitation_body: " -+ "in-front-of-NAT-Router"); -+ memcpy(&map_addr, &inside_addr, sizeof (map_addr)); -+ } -+ - sts = rtp_start_fwd(osip_message_get_call_id(mymsg), - client_id, - rtp_direction, -@@ -1205,17 +1219,21 @@ - - /* dump new body */ - sdp_message_to_str(sdp, &bodybuff); -+ bodybuflen=strlen(bodybuff); - - /* free sdp structure */ - sdp_message_free(sdp); - - /* include new body */ -- osip_message_set_body(mymsg, bodybuff); -+ osip_message_set_body(mymsg, bodybuff, bodybuflen); -+ if (sts != 0) { -+ ERROR("rewrite_invitation_body: unable to osip_message_set_body body"); -+ } - - /* free content length resource and include new one*/ - osip_content_length_free(mymsg->content_length); - mymsg->content_length=NULL; -- sprintf(clen,"%i",strlen(bodybuff)); -+ sprintf(clen,"%i",bodybuflen); - sts = osip_message_set_content_length(mymsg, clen); - - /* free old body */ -@@ -1224,11 +1242,12 @@ - if (configuration.debuglevel) - { /* just dump the buffer */ - char *tmp, *tmp2; -+ int tmplen; - sts = osip_message_get_body(mymsg, 0, &body); -- sts = osip_body_to_str(body, &tmp); -+ sts = osip_body_to_str(body, &tmp, &tmplen); - osip_content_length_to_str(mymsg->content_length, &tmp2); - DEBUG("Body after rewrite (clen=%s, strlen=%i):\n%s\n----", -- tmp2, strlen(tmp), tmp); -+ tmp2, tmplen, tmp); - osip_free(tmp); - osip_free(tmp2); - } diff --git a/net/siproxd/files/patch-src_register.c b/net/siproxd/files/patch-src_register.c deleted file mode 100644 index df8cf92d8dd..00000000000 --- a/net/siproxd/files/patch-src_register.c +++ /dev/null @@ -1,145 +0,0 @@ ---- src/register.c.orig Sat Jan 8 11:05:12 2005 -+++ src/register.c Sat Apr 9 16:16:48 2005 -@@ -35,7 +35,7 @@ - #include "siproxd.h" - #include "log.h" - --static char const ident[]="$Id: register.c,v 1.46 2005/01/08 10:05:12 hb9xar Exp $"; -+static char const ident[]="$Id: register.c,v 1.50 2005/04/03 20:55:30 hb9xar Exp $"; - - /* configuration storage */ - extern struct siproxd_config configuration; -@@ -255,7 +255,7 @@ - */ - if (expires > 0) { - /* -- * First make sure, we have a prober Contact header: -+ * First make sure, we have a proper Contact header: - * - url - * - url -> hostname - * -@@ -367,57 +367,56 @@ - strlen(configuration.masked_host.string[j])+1); - strcpy(urlmap[i].masq_url->host, configuration.masked_host.string[j]); - } -- -+ } else { /* if new entry */ -+ /* This is an existing entry */ - /* -- * for transparent proxying: force device to be masqueraded -- * as with the outbound IP -+ * Some phones (like BudgeTones *may* dynamically grab a SIP port -+ * so we might want to update the true_url and reg_url each time -+ * we get an REGISTER - */ -- if (force_lcl_masq) { -- struct in_addr addr; -- char *addrstr; -- -- if (get_ip_by_ifname(configuration.outbound_if, &addr) != -- STS_SUCCESS) { -- ERROR("can't find outbound interface %s - configuration error?", -- configuration.outbound_if); -- return STS_FAILURE; -- } -- -- /* host part */ -- addrstr = utils_inet_ntoa(addr); -- DEBUGC(DBCLASS_REG,"masquerading UA %s@%s local %s@%s", -- (url1_contact->username) ? url1_contact->username : "*NULL*", -- (url1_contact->host) ? url1_contact->host : "*NULL*", -- (url1_contact->username) ? url1_contact->username : "*NULL*", -- addrstr); -- urlmap[i].masq_url->host=realloc(urlmap[i].masq_url->host, -- strlen(addrstr)+1); -- strcpy(urlmap[i].masq_url->host, addrstr); - -- /* port number if required */ -- if (configuration.sip_listen_port != SIP_PORT) { -- urlmap[i].masq_url->port=realloc(urlmap[i].masq_url->port, 16); -- sprintf(urlmap[i].masq_url->port, "%i", -- configuration.sip_listen_port); -- } -- } -- -- } else { /* if new entry */ -- /* -- * Some phones (like BudgeTones *may* dynamically grab a SIP port -- * so we might want to update the true_url and reg_url each time -- * we get an REGISTER -- */ -- /* Contact: field */ -+ /* Contact: field (true_url) */ - osip_uri_free(urlmap[i].true_url); - osip_uri_clone( ((osip_contact_t*) - (ticket->sipmsg->contacts->node->element))->url, -- &urlmap[i].true_url); -- /* To: field */ -+ &urlmap[i].true_url); -+ /* To: field (reg_url) */ - osip_uri_free(urlmap[i].reg_url); - osip_uri_clone( ticket->sipmsg->to->url, -- &urlmap[i].reg_url); -+ &urlmap[i].reg_url); - } -+ -+ /* -+ * for proxying: force device to be masqueraded -+ * as with the outbound IP (masq_url) -+ */ -+ if (force_lcl_masq) { -+ struct in_addr addr; -+ char *addrstr; -+ -+ if (get_interface_ip(IF_OUTBOUND, &addr) != STS_SUCCESS) { -+ return STS_FAILURE; -+ } -+ -+ /* host part */ -+ addrstr = utils_inet_ntoa(addr); -+ DEBUGC(DBCLASS_REG,"masquerading UA %s@%s local %s@%s", -+ (url1_contact->username) ? url1_contact->username : "*NULL*", -+ (url1_contact->host) ? url1_contact->host : "*NULL*", -+ (url1_contact->username) ? url1_contact->username : "*NULL*", -+ addrstr); -+ urlmap[i].masq_url->host=realloc(urlmap[i].masq_url->host, -+ strlen(addrstr)+1); -+ strcpy(urlmap[i].masq_url->host, addrstr); -+ -+ /* port number if required */ -+ if (configuration.sip_listen_port != SIP_PORT) { -+ urlmap[i].masq_url->port=realloc(urlmap[i].masq_url->port, 16); -+ sprintf(urlmap[i].masq_url->port, "%i", -+ configuration.sip_listen_port); -+ } -+ } -+ - /* give some safety margin for the next update */ - if (expires > 0) expires+=30; - -@@ -495,6 +494,7 @@ - osip_via_t *via; - int port; - char *buffer; -+ int buflen; - struct in_addr addr; - osip_header_t *expires_hdr; - -@@ -550,7 +550,7 @@ - } - } - -- sts = osip_message_to_str(response, &buffer); -+ sts = osip_message_to_str(response, &buffer, &buflen); - if (sts != 0) { - ERROR("register_response: msg_2char failed"); - return STS_FAILURE; -@@ -563,7 +563,7 @@ - port=configuration.sip_listen_port; - } - -- sipsock_send(addr, port, ticket->protocol, buffer, strlen(buffer)); -+ sipsock_send(addr, port, ticket->protocol, buffer, buflen); - - /* free the resources */ - osip_message_free(response); diff --git a/net/siproxd/files/patch-src_sip_utilc.c b/net/siproxd/files/patch-src_sip_utilc.c deleted file mode 100644 index e525def7ec5..00000000000 --- a/net/siproxd/files/patch-src_sip_utilc.c +++ /dev/null @@ -1,154 +0,0 @@ ---- src/sip_utils.c.orig Sat Jan 8 11:05:13 2005 -+++ src/sip_utils.c Sat Apr 9 16:19:28 2005 -@@ -43,7 +43,7 @@ - #include "rewrite_rules.h" - #include "log.h" - --static char const ident[]="$Id: sip_utils.c,v 1.34 2005/01/08 10:05:13 hb9xar Exp $"; -+static char const ident[]="$Id: sip_utils.c,v 1.37 2005/03/01 21:36:48 hb9xar Exp $"; - - - /* configuration storage */ -@@ -174,11 +174,8 @@ - int is_via_local (osip_via_t *via) { - int sts, found; - struct in_addr addr_via, addr_myself; -- char *my_interfaces[]= -- { configuration.inbound_if, configuration.outbound_if, (char*)-1 }; - int port; - int i; -- char *ptr; - - if (via==NULL) { - ERROR("called is_via_local with NULL via"); -@@ -197,19 +194,14 @@ - } - - found=0; -- for (i=0; ; i++) { -+ for (i=0; i<2; i++) { - /* -- * try to search by interface name first -+ * search my in/outbound interfaces - */ -- ptr=my_interfaces[i]; -- if (ptr==(char*)-1) break; /* end of list mark */ -- -- if (ptr) { -- DEBUGC(DBCLASS_BABBLE,"resolving IP of interface %s",ptr); -- if (get_ip_by_ifname(ptr, &addr_myself) != STS_SUCCESS) { -- ERROR("can't find interface %s - configuration error?", ptr); -- continue; -- } -+ DEBUGC(DBCLASS_BABBLE,"resolving IP of interface %s", -+ (i==IF_INBOUND)? "inbound":"outbound"); -+ if (get_interface_ip(i, &addr_myself) != STS_SUCCESS) { -+ continue; - } - - /* check the extracted VIA against my own host addresses */ -@@ -390,11 +382,8 @@ - osip_message_t *sip=ticket->sipmsg; - int found; - struct in_addr addr_uri, addr_myself; -- char *my_interfaces[]= -- { configuration.inbound_if, configuration.outbound_if, (char*)-1 }; - int port; - int i; -- char *ptr; - - if (sip==NULL) { - ERROR("called is_sipuri_local with NULL sip"); -@@ -416,19 +405,14 @@ - } - - found=0; -- for (i=0; ; i++) { -+ for (i=0; i<2; i++) { - /* -- * try to search by interface name first -+ * search my in/outbound interfaces - */ -- ptr=my_interfaces[i]; -- if (ptr==(char*)-1) break; /* end of list mark */ -- -- if (ptr) { -- DEBUGC(DBCLASS_BABBLE,"resolving IP of interface %s",ptr); -- if (get_ip_by_ifname(ptr, &addr_myself) != STS_SUCCESS) { -- ERROR("can't find interface %s - configuration error?", ptr); -- continue; -- } -+ DEBUGC(DBCLASS_BABBLE,"resolving IP of interface %s", -+ (i==IF_INBOUND)? "inbound":"outbound"); -+ if (get_interface_ip(i, &addr_myself) != STS_SUCCESS) { -+ continue; - } - - /* check the extracted HOST against my own host addresses */ -@@ -533,6 +517,7 @@ - osip_via_t *via; - int port; - char *buffer; -+ int buflen; - struct in_addr addr; - - /* create the response template */ -@@ -563,7 +548,7 @@ - } - } - -- sts = osip_message_to_str(response, &buffer); -+ sts = osip_message_to_str(response, &buffer, &buflen); - if (sts != 0) { - ERROR("sip_gen_response: msg_2char failed"); - return STS_FAILURE; -@@ -577,7 +562,7 @@ - } - - /* send to destination */ -- sipsock_send(addr, port, ticket->protocol, buffer, strlen(buffer)); -+ sipsock_send(addr, port, ticket->protocol, buffer, buflen); - - /* free the resources */ - osip_message_free(response); -@@ -601,25 +586,26 @@ - osip_via_t *via; - int sts; - char branch_id[VIA_BRANCH_SIZE]; -+ char *myaddr; - -- if (interface == IF_OUTBOUND) { -- if (get_ip_by_ifname(configuration.outbound_if, &addr) != STS_SUCCESS) { -- ERROR("can't find interface %s - configuration error?", -- configuration.outbound_if); -- return STS_FAILURE; -- } -- } else { -- if (get_ip_by_ifname(configuration.inbound_if, &addr) != STS_SUCCESS) { -- ERROR("can't find inbound interface %s - configuration error?", -- configuration.inbound_if); -- return STS_FAILURE; -- } -+ if (get_interface_ip(interface, &addr) != STS_SUCCESS) { -+ return STS_FAILURE; - } - - sts = sip_calculate_branch_id(ticket, branch_id); - -- sprintf(tmp, "SIP/2.0/UDP %s:%i;branch=%s;", utils_inet_ntoa(addr), -- configuration.sip_listen_port, branch_id); -+ myaddr=utils_inet_ntoa(addr); -+//&&&& -+#if 0 -+ sprintf(tmp, "SIP/2.0/UDP %s:%i;branch=%s;sent-by=%s:%i", -+ myaddr, configuration.sip_listen_port, -+ branch_id, -+ myaddr, configuration.sip_listen_port); -+#else -+ sprintf(tmp, "SIP/2.0/UDP %s:%i;branch=%s", -+ myaddr, configuration.sip_listen_port, -+ branch_id); -+#endif - DEBUGC(DBCLASS_BABBLE,"adding VIA:%s",tmp); - - sts = osip_via_init(&via); diff --git a/net/siproxd/files/patch-src_siproxd.c b/net/siproxd/files/patch-src_siproxd.c deleted file mode 100644 index 45542c7193b..00000000000 --- a/net/siproxd/files/patch-src_siproxd.c +++ /dev/null @@ -1,84 +0,0 @@ ---- src/siproxd.c.orig Sat Jan 8 11:41:46 2005 -+++ src/siproxd.c Sat Apr 9 15:50:49 2005 -@@ -38,7 +38,7 @@ - #include "siproxd.h" - #include "log.h" - --static char const ident[]="$Id: siproxd.c,v 1.57 2005/01/08 10:41:46 hb9xar Exp $"; -+static char const ident[]="$Id: siproxd.c,v 1.60 2005/03/01 21:36:48 hb9xar Exp $"; - - /* configuration storage */ - struct siproxd_config configuration; -@@ -82,6 +82,7 @@ - { - int sts; - int i; -+ int buflen; - int access; - char buff [BUFFER_SIZE]; - sip_ticket_t ticket; -@@ -291,8 +292,9 @@ - /* got input, process */ - DEBUGC(DBCLASS_BABBLE,"back from sipsock_wait"); - -- i=sipsock_read(&buff, sizeof(buff)-1, &ticket.from, &ticket.protocol); -- buff[i]='\0'; -+ buflen=sipsock_read(&buff, sizeof(buff)-1, &ticket.from, -+ &ticket.protocol); -+ buff[buflen]='\0'; - - /* evaluate the access lists (IP based filter)*/ - access=accesslist_check(ticket.from); -@@ -302,7 +304,7 @@ - } - - /* integrity checks */ -- sts=security_check_raw(buff, i); -+ sts=security_check_raw(buff, buflen); - if (sts != STS_SUCCESS) { - DEBUGC(DBCLASS_SIP,"security check (raw) failed"); - continue; /* there are no resources to free */ -@@ -321,10 +323,10 @@ - * Proxy Behavior - Request Validation - Reasonable Syntax - * (parse the received message) - */ -- sts=osip_message_parse(ticket.sipmsg, buff); -+ sts=osip_message_parse(ticket.sipmsg, buff, buflen); - if (sts != 0) { - ERROR("osip_message_parse() failed... this is not good"); -- DUMP_BUFFER(-1, buff, i); -+ DUMP_BUFFER(-1, buff, buflen); - goto end_loop; /* skip and free resources */ - } - -@@ -332,7 +334,7 @@ - sts=security_check_sip(&ticket); - if (sts != STS_SUCCESS) { - ERROR("security_check_sip() failed... this is not good"); -- DUMP_BUFFER(-1, buff, i); -+ DUMP_BUFFER(-1, buff, buflen); - goto end_loop; /* skip and free resources */ - } - -@@ -422,10 +424,8 @@ - dest_port= (url->port)?atoi(url->port):SIP_PORT; - - if ( (get_ip_by_host(url->host, &addr1) == STS_SUCCESS) && -- (get_ip_by_ifname(configuration.inbound_if,&addr2) == -- STS_SUCCESS) && -- (get_ip_by_ifname(configuration.outbound_if,&addr3) == -- STS_SUCCESS)) { -+ (get_interface_ip(IF_INBOUND,&addr2) == STS_SUCCESS) && -+ (get_interface_ip(IF_OUTBOUND,&addr3) == STS_SUCCESS)) { - - if ((configuration.sip_listen_port == dest_port) && - ((memcmp(&addr1, &addr2, sizeof(addr1)) == 0) || -@@ -455,7 +455,7 @@ - * If not, send back error to UA and - * skip any proxying attempt - */ -- } else if (get_ip_by_ifname(configuration.outbound_if,NULL) != -+ } else if (get_interface_ip(IF_OUTBOUND,NULL) != - STS_SUCCESS) { - DEBUGC(DBCLASS_SIP, "got a %s to proxy, but outbound interface " - "is down", (MSG_IS_REQUEST(ticket.sipmsg))? "REQ" : "RES"); diff --git a/net/siproxd/files/patch-src_siproxd.h b/net/siproxd/files/patch-src_siproxd.h deleted file mode 100644 index 843de58c883..00000000000 --- a/net/siproxd/files/patch-src_siproxd.h +++ /dev/null @@ -1,80 +0,0 @@ ---- src/siproxd.h.orig Sat Jan 8 11:05:13 2005 -+++ src/siproxd.h Tue Mar 1 22:36:48 2005 -@@ -18,7 +18,7 @@ - Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - */ - --/* $Id: siproxd.h,v 1.48 2005/01/08 10:05:13 hb9xar Exp $ */ -+/* $Id: siproxd.h,v 1.51 2005/03/01 21:36:48 hb9xar Exp $ */ - - #ifdef DMALLOC - #include <dmalloc.h> -@@ -60,6 +60,7 @@ - int debugport; - char *inbound_if; - char *outbound_if; -+ char *outbound_host; - int sip_listen_port; - int daemonize; - int silence_log; -@@ -147,6 +148,7 @@ - int get_ip_by_host(char *hostname, struct in_addr *addr); /*X*/ - void secure_enviroment (void); - int get_ip_by_ifname(char *ifname, struct in_addr *retaddr); /*X*/ -+int get_interface_ip(int interface, struct in_addr *retaddr); /*X*/ - char *utils_inet_ntoa(struct in_addr in); - int utils_inet_aton(const char *cp, struct in_addr *inp); - -@@ -159,8 +161,6 @@ - int is_sipuri_local (sip_ticket_t *ticket); /*X*/ - int check_rewrite_rq_uri (osip_message_t *sip); /*X*/ - int sip_gen_response(sip_ticket_t *ticket, int code); /*X*/ --#define IF_OUTBOUND 0 --#define IF_INBOUND 1 - int sip_add_myvia (sip_ticket_t *ticket, int interface); /*X*/ - int sip_del_myvia (sip_ticket_t *ticket); /*X*/ - int sip_rewrite_contact (sip_ticket_t *ticket, int direction); /*X*/ -@@ -176,7 +176,7 @@ - int rtpproxy_init( void ); /*X*/ - int rtp_start_fwd (osip_call_id_t *callid, char *client_id, /*X*/ - int direction, int media_stream_no, -- struct in_addr outbound_ipaddr, int *outboundport, -+ struct in_addr outbound_ipaddr, int *outboundport, - struct in_addr lcl_client_ipaddr, int lcl_clientport); - int rtp_stop_fwd (osip_call_id_t *callid, int direction); /*X*/ - void rtpproxy_kill( void ); /*X*/ -@@ -201,6 +201,12 @@ - struct in_addr local_ipaddr, int local_port, - struct in_addr remote_ipaddr, int remote_port); - -+/* sip_layer.c */ -+int sip_message_parse(osip_message_t * sip, const char *buf, int len); -+int sip_message_to_str(osip_message_t * sip, char **dest, int *len); -+int sip_body_to_str(const osip_body_t * body, char **dest, int *len); -+int sip_message_set_body(osip_message_t * sip, const char *buf, int len); -+ - - /* - * some constant definitions -@@ -236,8 +242,8 @@ - #define SEC_MINLEN 16 /* minimum received length */ - #define SEC_MAXLINELEN 1024 /* maximum acceptable length of one line - in the SIP telegram (security check) -- Careful: Proxy-Authorization lines may -- get quite long */ -+ Careful: Proxy-Authorization lines may -+ get quite long */ - - /* symbols for access control */ - #define ACCESSCTL_SIP 1 /* for access control - SIP allowed */ -@@ -253,6 +259,10 @@ - /* symbolic direction of data */ - #define DIR_INCOMING 1 - #define DIR_OUTGOING 2 -+ -+/* Interfaces */ -+#define IF_OUTBOUND 0 -+#define IF_INBOUND 1 - - /* various */ - #ifndef satoi diff --git a/net/siproxd/files/patch-src_utils.c b/net/siproxd/files/patch-src_utils.c deleted file mode 100644 index 346d40a23e7..00000000000 --- a/net/siproxd/files/patch-src_utils.c +++ /dev/null @@ -1,60 +0,0 @@ ---- src/utils.c.orig Sat Jan 8 11:05:13 2005 -+++ src/utils.c Tue Mar 1 22:36:48 2005 -@@ -44,7 +44,7 @@ - #include "siproxd.h" - #include "log.h" - --static char const ident[]="$Id: utils.c,v 1.41 2005/01/08 10:05:13 hb9xar Exp $"; -+static char const ident[]="$Id: utils.c,v 1.42 2005/03/01 21:36:48 hb9xar Exp $"; - - /* configuration storage */ - extern struct siproxd_config configuration; -@@ -288,6 +288,48 @@ - passwd->pw_uid, (sts==0)?"Ok":"Failed"); - } - } -+} -+ -+ -+/* -+ * get_interface_ip: -+ * fetches own IP address by interface INBOUND/OUTBOUND -+ * -+ * STS_SUCCESS on returning a valid IP and interface is UP -+ * STS_FAILURE if interface is DOWN or other problem -+ */ -+int get_interface_ip(int interface, struct in_addr *retaddr) { -+ int sts=STS_FAILURE; -+ char *tmp=NULL; -+ -+ if (interface == IF_INBOUND) { -+ tmp = configuration.inbound_if; -+ } else if (interface == IF_OUTBOUND) { -+ tmp = configuration.outbound_if; -+ } -+ -+ if ((interface == IF_OUTBOUND) && -+ (configuration.outbound_host) && -+ (strcmp(configuration.outbound_host, "")!=0)) { -+ DEBUGC(DBCLASS_DNS, "fetching outbound IP by HOSTNAME"); -+ if (retaddr) { -+ sts = get_ip_by_host(configuration.outbound_host, retaddr); -+ } else { -+ sts = STS_SUCCESS; -+ } -+ -+ } else if (tmp && (strcmp(tmp, "")!=0)) { -+ DEBUGC(DBCLASS_DNS, "fetching interface IP by INTERFACE [%i]", interface); -+ sts = get_ip_by_ifname(tmp, retaddr); -+ if (sts != STS_SUCCESS) { -+ ERROR("can't find interface %s - configuration error?", tmp); -+ } -+ -+ } else { -+ ERROR("Don't know what interface to look for - configuration error?"); -+ } -+ -+ return sts; - } - - |