diff options
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | src/sock.c | 18 | 
2 files changed, 22 insertions, 1 deletions
| @@ -1,3 +1,8 @@ +2002-04-13  Robert James Kaes  <rjkaes@flarenet.com> + +	* src/sock.c (opensock): If the Listen directive is in use, then +	we should bind outgoing address to this address. +  2002-04-12  Robert James Kaes  <rjkaes@flarenet.com>  	* src/scanner.l: @@ -1,4 +1,4 @@ -/* $Id: sock.c,v 1.23 2001-12-24 00:01:32 rjkaes Exp $ +/* $Id: sock.c,v 1.24 2002-04-13 05:20:19 rjkaes Exp $   *   * Sockets are created and destroyed here. When a new connection comes in from   * a client, we need to copy the socket and the create a second socket to the @@ -97,6 +97,7 @@ opensock(char *ip_addr, uint16_t port)  {  	int sock_fd;  	struct sockaddr_in port_info; +	struct sockaddr_in bind_addr;  	int ret;  	assert(ip_addr != NULL); @@ -124,6 +125,21 @@ opensock(char *ip_addr, uint16_t port)  		return -1;  	} +	/* Bind to our listening address*/ +	if (config.ipAddr) { +		memset(&bind_addr, 0, sizeof(bind_addr)); +		bind_addr.sin_family = AF_INET; +		bind_addr.sin_addr.s_addr = inet_addr(config.ipAddr); + +		ret = bind(sock_fd, (struct sockaddr *)&bind_addr, sizeof(bind_addr)); +		if (ret < 0) { +			log_message(LOG_ERR, "Could not bind local address \"%\" because of %s", +				    config.ipAddr, +				    strerror(errno)); +			return -1; +		} +	} +  	if (connect(sock_fd, (struct sockaddr *) &port_info, sizeof(port_info)) < 0) {  		log_message(LOG_ERR, "opensock: connect() error \"%s\".",  			    strerror(errno)); | 
