masqmail

changeset 411:9b93c0a3bd8c

Ensure lvals, rvals and components of address strucs are stripped.
author markus schnalke <meillo@marmaro.de>
date Wed, 29 Feb 2012 12:06:33 +0100 (2012-02-29)
parents cff967b2f51e
children 8a62bebda631
files src/accept.c src/address.c src/conf.c
diffstat 3 files changed, 16 insertions(+), 17 deletions(-) [+]
line diff
     1.1 --- a/src/accept.c	Wed Feb 29 12:05:47 2012 +0100
     1.2 +++ b/src/accept.c	Wed Feb 29 12:06:33 2012 +0100
     1.3 @@ -199,8 +199,7 @@
     1.4  
     1.5  		DEBUG(5) debugf("hdr->value = '%s'\n", hdr->value);
     1.6  
     1.7 -		addr = g_strdup(hdr->value);
     1.8 -		g_strchomp(addr);
     1.9 +		addr = g_strstrip(g_strdup(hdr->value));
    1.10  		msg->return_path = create_address_qualified(addr,
    1.11  				FALSE, msg->received_host);
    1.12  		if (msg->return_path) {
     2.1 --- a/src/address.c	Wed Feb 29 12:05:47 2012 +0100
     2.2 +++ b/src/address.c	Wed Feb 29 12:06:33 2012 +0100
     2.3 @@ -37,7 +37,7 @@
     2.4  	address *addr = create_address(path, is_rfc821);
     2.5  
     2.6  	if (addr && !addr->domain) {
     2.7 -		addr->domain = g_strdup(domain);
     2.8 +		addr->domain = g_strstrip(g_strdup(domain));
     2.9  	}
    2.10  	return addr;
    2.11  }
    2.12 @@ -50,8 +50,8 @@
    2.13  
    2.14  	if (addr) {
    2.15  		memset(addr, 0, sizeof(address));
    2.16 -		addr->address = g_strchomp(g_strdup(path));
    2.17 -		addr->local_part = g_strdup(addr->address);
    2.18 +		addr->address = g_strstrip(g_strdup(path));
    2.19 +		addr->local_part = g_strstrip(g_strdup(addr->address));
    2.20  		addr->domain = g_strdup("localhost");  /* quick hack */
    2.21  	}
    2.22  	return addr;
    2.23 @@ -78,10 +78,11 @@
    2.24  	if (!(addr = g_malloc(sizeof(address)))) {
    2.25  		return NULL;
    2.26  	}
    2.27 -	addr->address = g_strdup(orig->address);
    2.28 -	addr->local_part = l_part ? g_strdup(l_part) :
    2.29 -			g_strdup(orig->local_part);
    2.30 -	addr->domain = dom ? g_strdup(dom) : g_strdup(orig->domain);
    2.31 +	addr->address = g_strstrip(g_strdup(orig->address));
    2.32 +	addr->local_part = g_strstrip(l_part ? g_strdup(l_part) :
    2.33 +			g_strdup(orig->local_part));
    2.34 +	addr->domain = g_strstrip(dom ? g_strdup(dom) :
    2.35 +			g_strdup(orig->domain));
    2.36  	addr->flags = 0;
    2.37  	addr->children = NULL;
    2.38  	addr->parent = NULL;
    2.39 @@ -164,14 +165,12 @@
    2.40  {
    2.41  	static gchar *buffer = NULL;
    2.42  
    2.43 -	if (!addr) {
    2.44 -		g_free(buffer);
    2.45 -		buffer = NULL;
    2.46 -		return NULL;
    2.47 -	}
    2.48  	if (buffer) {
    2.49  		g_free(buffer);
    2.50  	}
    2.51 +	if (!addr) {
    2.52 +		return NULL;
    2.53 +	}
    2.54  	if (!*addr->local_part) {
    2.55  		buffer = g_strdup("<>");
    2.56  	} else {
     3.1 --- a/src/conf.c	Wed Feb 29 12:05:47 2012 +0100
     3.2 +++ b/src/conf.c	Wed Feb 29 12:06:33 2012 +0100
     3.3 @@ -380,8 +380,8 @@
     3.4  	if (!read_lval(in, lval, lsize)) {
     3.5  		return FALSE;
     3.6  	}
     3.7 -
     3.8 -	DEBUG(9) fprintf(stderr, "  lval = %s\n", lval);
     3.9 +	g_strstrip(lval);
    3.10 +	DEBUG(9) fprintf(stderr, "  lval = `%s'\n", lval);
    3.11  	if ((c = fgetc(in) != '=')) {
    3.12  		fprintf(stderr, "'=' expected after %s, char was '%c'\n",
    3.13  				lval, c);
    3.14 @@ -389,7 +389,8 @@
    3.15  	if (!read_rval(in, rval, rsize)) {
    3.16  		return FALSE;
    3.17  	}
    3.18 -	DEBUG(9) fprintf(stderr, "  rval = %s\n", rval);
    3.19 +	g_strstrip(rval);
    3.20 +	DEBUG(9) fprintf(stderr, "  rval = `%s'\n", rval);
    3.21  	return TRUE;
    3.22  }
    3.23