1
0
mirror of https://git.FreeBSD.org/ports.git synced 2025-01-23 09:10:43 +00:00

- Update to 0.5.10

- Patch for libosip2-2.2.x

PR:		ports/79720
Submitted by:	Frank W. Josellis <frank@dynamical-systems.org> (maintainer)
This commit is contained in:
Pav Lucistnik 2005-04-09 20:04:22 +00:00
parent e84810eec1
commit 004e68b8d6
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=132826
9 changed files with 746 additions and 8 deletions

View File

@ -6,8 +6,7 @@
#
PORTNAME= siproxd
PORTVERSION= 0.5.9
PORTREVISION= 1
PORTVERSION= 0.5.10
CATEGORIES= net
MASTER_SITES= ${MASTER_SITE_SOURCEFORGE}
MASTER_SITE_SUBDIR= siproxd
@ -17,8 +16,6 @@ COMMENT= A proxy/masquerading daemon for the SIP protocol
LIB_DEPENDS= osip2.3:${PORTSDIR}/net/libosip2
BROKEN= does not compile with libosip2-2.2.0 or newer
USE_REINPLACE= yes
USE_GETOPT_LONG=yes
USE_RC_SUBR= yes

View File

@ -1,2 +1,2 @@
MD5 (siproxd-0.5.9.tar.gz) = 7428bc04eb8d60a5741d68190b06f10b
SIZE (siproxd-0.5.9.tar.gz) = 198530
MD5 (siproxd-0.5.10.tar.gz) = f7c867affe6f1c6674bf174af6c9dd32
SIZE (siproxd-0.5.10.tar.gz) = 201888

View File

@ -1,5 +1,5 @@
--- doc/siproxd.conf.example.orig Sun May 9 14:53:06 2004
+++ doc/siproxd.conf.example Mon Oct 11 21:25:41 2004
--- 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.

View File

@ -0,0 +1,218 @@
--- 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);
}

View File

@ -0,0 +1,145 @@
--- 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);

View File

@ -0,0 +1,154 @@
--- 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);

View File

@ -0,0 +1,84 @@
--- 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");

View File

@ -0,0 +1,80 @@
--- 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

View File

@ -0,0 +1,60 @@
--- 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;
}