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