Blame SOURCES/dovecot-2.3.10-smtppre.patch

eb6ccf
diff -up dovecot-2.3.8/src/lib-smtp/smtp-address.c.smtppre dovecot-2.3.8/src/lib-smtp/smtp-address.c
eb6ccf
--- dovecot-2.3.8/src/lib-smtp/smtp-address.c.smtppre	2019-10-08 10:46:18.000000000 +0200
eb6ccf
+++ dovecot-2.3.8/src/lib-smtp/smtp-address.c	2020-05-29 19:11:19.340621409 +0200
eb6ccf
@@ -467,7 +467,7 @@ void smtp_address_detail_parse(pool_t po
eb6ccf
 		*detail_r = p+1;
eb6ccf
 	}
eb6ccf
 
eb6ccf
-	if (address->domain == NULL)
eb6ccf
+	if (address->domain == NULL || *address->domain == '\0')
eb6ccf
 		*username_r = user;
eb6ccf
 	else if (strchr(user, '@') == NULL ) {
eb6ccf
 		/* username is just glued to the domain... no SMTP escaping */
eb6ccf
@@ -548,7 +548,7 @@ void smtp_address_write(string_t *out,
eb6ccf
 	if (quoted)
eb6ccf
 		str_append_c(out, '\"');
eb6ccf
 
eb6ccf
-	if (address->domain == NULL)
eb6ccf
+	if (address->domain == NULL || *address->domain == '\0')
eb6ccf
 		return;
eb6ccf
 
eb6ccf
 	str_append_c(out, '@');
eb6ccf
@@ -587,8 +587,12 @@ void smtp_address_init(struct smtp_addre
eb6ccf
 	const char *localpart, const char *domain)
eb6ccf
 {
eb6ccf
 	i_zero(address);
eb6ccf
+	if (localpart == NULL || *localpart == '\0')
eb6ccf
+		return;
eb6ccf
+
eb6ccf
 	address->localpart = localpart;
eb6ccf
-	address->domain = (localpart == NULL ? NULL : domain);
eb6ccf
+	if (domain != NULL && *domain != '\0')
eb6ccf
+		address->domain = domain;
eb6ccf
 }
eb6ccf
 
eb6ccf
 int smtp_address_init_from_msg(struct smtp_address *address,
eb6ccf
@@ -597,7 +601,7 @@ int smtp_address_init_from_msg(struct sm
eb6ccf
 	const char *p;
eb6ccf
 
eb6ccf
 	i_zero(address);
eb6ccf
-	if (msg_addr->mailbox == NULL)
eb6ccf
+	if (msg_addr->mailbox == NULL || *msg_addr->mailbox == '\0')
eb6ccf
 		return 0;
eb6ccf
 
eb6ccf
 	/* The message_address_parse() function allows UTF-8 codepoints in
eb6ccf
@@ -609,7 +613,8 @@ int smtp_address_init_from_msg(struct sm
eb6ccf
 	}
eb6ccf
 
eb6ccf
 	address->localpart = msg_addr->mailbox;
eb6ccf
-	address->domain = msg_addr->domain;
eb6ccf
+	if (msg_addr->domain != NULL && *msg_addr->domain != '\0')
eb6ccf
+		address->domain = msg_addr->domain;
eb6ccf
 	return 0;
eb6ccf
 }
eb6ccf
 
eb6ccf
@@ -617,8 +622,8 @@ struct smtp_address *
eb6ccf
 smtp_address_clone(pool_t pool, const struct smtp_address *src)
eb6ccf
 {
eb6ccf
 	struct smtp_address *new;
eb6ccf
-	size_t size, lpsize, dsize = 0;
eb6ccf
-	char *data, *localpart, *domain = NULL;
eb6ccf
+	size_t size, lpsize = 0, dsize = 0;
eb6ccf
+	char *data, *localpart = NULL, *domain = NULL;
eb6ccf
 
eb6ccf
 	if (smtp_address_isnull(src))
eb6ccf
 		return NULL;
eb6ccf
@@ -626,17 +631,21 @@ smtp_address_clone(pool_t pool, const st
eb6ccf
 	/* @UNSAFE */
eb6ccf
 
eb6ccf
 	size = sizeof(struct smtp_address);
eb6ccf
-	lpsize = strlen(src->localpart) + 1;
eb6ccf
-	size = MALLOC_ADD(size, lpsize);
eb6ccf
-	if (src->domain != NULL) {
eb6ccf
+	if (src->localpart != NULL && *src->localpart != '\0') {
eb6ccf
+		lpsize = strlen(src->localpart) + 1;
eb6ccf
+		size = MALLOC_ADD(size, lpsize);
eb6ccf
+	}
eb6ccf
+	if (src->domain != NULL && *src->domain != '\0') {
eb6ccf
 		dsize = strlen(src->domain) + 1;
eb6ccf
 		size = MALLOC_ADD(size, dsize);
eb6ccf
 	}
eb6ccf
 
eb6ccf
 	data = p_malloc(pool, size);
eb6ccf
 	new = (struct smtp_address *)data;
eb6ccf
-	localpart = PTR_OFFSET(data, sizeof(*new));
eb6ccf
-	memcpy(localpart, src->localpart, lpsize);
eb6ccf
+	if (lpsize > 0) {
eb6ccf
+		localpart = PTR_OFFSET(data, sizeof(*new));
eb6ccf
+		memcpy(localpart, src->localpart, lpsize);
eb6ccf
+	}
eb6ccf
 	if (dsize > 0) {
eb6ccf
 		domain = PTR_OFFSET(data, sizeof(*new) + lpsize);
eb6ccf
 		memcpy(domain, src->domain, dsize);
eb6ccf
@@ -681,8 +690,8 @@ smtp_address_clone_temp(const struct smt
eb6ccf
 		return NULL;
eb6ccf
 
eb6ccf
 	new = t_new(struct smtp_address, 1);
eb6ccf
-	new->localpart = t_strdup(src->localpart);
eb6ccf
-	new->domain = t_strdup(src->domain);
eb6ccf
+	new->localpart = t_strdup_empty(src->localpart);
eb6ccf
+	new->domain = t_strdup_empty(src->domain);
eb6ccf
 	return new;
eb6ccf
 }
eb6ccf
 
eb6ccf
@@ -720,7 +729,7 @@ smtp_address_add_detail(pool_t pool, con
eb6ccf
 	new_addr = p_new(pool, struct smtp_address, 1);
eb6ccf
 	new_addr->localpart = p_strconcat(pool,
eb6ccf
 		address->localpart, delim, detail, NULL);
eb6ccf
-	new_addr->domain = p_strdup(pool, address->domain);
eb6ccf
+	new_addr->domain = p_strdup_empty(pool, address->domain);
eb6ccf
 
eb6ccf
 	return new_addr;
eb6ccf
 }
eb6ccf
@@ -737,7 +746,7 @@ smtp_address_add_detail_temp(const struc
eb6ccf
 	new_addr = t_new(struct smtp_address, 1);
eb6ccf
 	new_addr->localpart = t_strconcat(
eb6ccf
 		address->localpart, delim, detail, NULL);
eb6ccf
-	new_addr->domain = t_strdup(address->domain);
eb6ccf
+	new_addr->domain = t_strdup_empty(address->domain);
eb6ccf
 
eb6ccf
 	return new_addr;
eb6ccf
 }