Blame SOURCES/dovecot-2.3.13-CVE_2020_25275-part4.patch

2c808a
From 62061e8cf68f506c0ccaaba21fd4174764ca875f Mon Sep 17 00:00:00 2001
2c808a
From: Timo Sirainen <timo.sirainen@open-xchange.com>
2c808a
Date: Mon, 17 Aug 2020 18:15:35 +0300
2c808a
Subject: [PATCH] imap-login: Split off client_invalid_command()
2c808a
2c808a
---
2c808a
 src/imap-login/imap-login-client.c | 27 +++++++++++++++++----------
2c808a
 1 file changed, 17 insertions(+), 10 deletions(-)
2c808a
2c808a
diff --git a/src/imap-login/imap-login-client.c b/src/imap-login/imap-login-client.c
2c808a
index e2af176309..ce5049d567 100644
2c808a
--- a/src/imap-login/imap-login-client.c
2c808a
+++ b/src/imap-login/imap-login-client.c
2c808a
@@ -194,6 +194,22 @@ static int client_command_execute(struct imap_client *client, const char *cmd,
2c808a
 	return login_cmd->func(client, args);
2c808a
 }
2c808a
 
2c808a
+static bool client_invalid_command(struct imap_client *client)
2c808a
+{
2c808a
+	if (*client->cmd_tag == '\0')
2c808a
+		client->cmd_tag = "*";
2c808a
+	if (++client->common.bad_counter >= CLIENT_MAX_BAD_COMMANDS) {
2c808a
+		client_send_reply(&client->common, IMAP_CMD_REPLY_BYE,
2c808a
+				  "Too many invalid IMAP commands.");
2c808a
+		client_destroy(&client->common,
2c808a
+			       "Disconnected: Too many invalid commands");
2c808a
+		return FALSE;
2c808a
+	}
2c808a
+	client_send_reply(&client->common, IMAP_CMD_REPLY_BAD,
2c808a
+			  "Error in IMAP command received by server.");
2c808a
+	return TRUE;
2c808a
+}
2c808a
+
2c808a
 static bool imap_is_valid_tag(const char *tag)
2c808a
 {
2c808a
 	for (; *tag != '\0'; tag++) {
2c808a
@@ -326,17 +342,8 @@ static bool imap_client_input_next_cmd(struct client *_client)
2c808a
 			"not the command name. Add that before the command, "
2c808a
 			"like: a login user pass");
2c808a
 	} else if (ret < 0) {
2c808a
-		if (*client->cmd_tag == '\0')
2c808a
-			client->cmd_tag = "*";
2c808a
-		if (++client->common.bad_counter >= CLIENT_MAX_BAD_COMMANDS) {
2c808a
-			client_send_reply(&client->common, IMAP_CMD_REPLY_BYE,
2c808a
-				"Too many invalid IMAP commands.");
2c808a
-			client_destroy(&client->common,
2c808a
-				"Disconnected: Too many invalid commands");
2c808a
+		if (!client_invalid_command(client))
2c808a
 			return FALSE;
2c808a
-		}
2c808a
-		client_send_reply(&client->common, IMAP_CMD_REPLY_BAD,
2c808a
-			"Error in IMAP command received by server.");
2c808a
 	}
2c808a
 
2c808a
 	return ret != 0 && !client->common.destroyed;