|
|
2c808a |
From 0386140f61f9ba62225e90b419215f72bba6ad8b Mon Sep 17 00:00:00 2001
|
|
|
2c808a |
From: Timo Sirainen <timo.sirainen@open-xchange.com>
|
|
|
2c808a |
Date: Mon, 17 Aug 2020 18:11:36 +0300
|
|
|
2c808a |
Subject: [PATCH] imap: Use imap_parser_read_tag() and _read_command_name()
|
|
|
2c808a |
|
|
|
2c808a |
---
|
|
|
2c808a |
src/imap/imap-client.c | 33 ++++++++++++++++++++++-----------
|
|
|
2c808a |
1 file changed, 22 insertions(+), 11 deletions(-)
|
|
|
2c808a |
|
|
|
2c808a |
diff --git a/src/imap/imap-client.c b/src/imap/imap-client.c
|
|
|
2c808a |
index 0bf03caa97..95e57dbf53 100644
|
|
|
2c808a |
--- a/src/imap/imap-client.c
|
|
|
2c808a |
+++ b/src/imap/imap-client.c
|
|
|
2c808a |
@@ -1182,6 +1182,9 @@ client_command_failed_early(struct client_command_context **_cmd,
|
|
|
2c808a |
{
|
|
|
2c808a |
struct client_command_context *cmd = *_cmd;
|
|
|
2c808a |
|
|
|
2c808a |
+ /* ignore the rest of this line */
|
|
|
2c808a |
+ cmd->client->input_skip_line = TRUE;
|
|
|
2c808a |
+
|
|
|
2c808a |
io_loop_time_refresh();
|
|
|
2c808a |
command_stats_start(cmd);
|
|
|
2c808a |
client_send_command_error(cmd, error);
|
|
|
2c808a |
@@ -1193,6 +1196,8 @@ static bool client_command_input(struct client_command_context *cmd)
|
|
|
2c808a |
{
|
|
|
2c808a |
struct client *client = cmd->client;
|
|
|
2c808a |
struct command *command;
|
|
|
2c808a |
+ const char *tag, *name;
|
|
|
2c808a |
+ int ret;
|
|
|
2c808a |
|
|
|
2c808a |
if (cmd->func != NULL) {
|
|
|
2c808a |
/* command is being executed - continue it */
|
|
|
2c808a |
@@ -1207,27 +1212,33 @@ static bool client_command_input(struct client_command_context *cmd)
|
|
|
2c808a |
}
|
|
|
2c808a |
|
|
|
2c808a |
if (cmd->tag == NULL) {
|
|
|
2c808a |
- cmd->tag = imap_parser_read_word(cmd->parser);
|
|
|
2c808a |
- if (cmd->tag == NULL)
|
|
|
2c808a |
+ ret = imap_parser_read_tag(cmd->parser, &tag;;
|
|
|
2c808a |
+ if (ret == 0)
|
|
|
2c808a |
return FALSE; /* need more data */
|
|
|
2c808a |
- cmd->tag = p_strdup(cmd->pool, cmd->tag);
|
|
|
2c808a |
+ if (ret < 0) {
|
|
|
2c808a |
+ client_command_failed_early(&cmd, "Invalid tag.");
|
|
|
2c808a |
+ return TRUE;
|
|
|
2c808a |
+ }
|
|
|
2c808a |
+ cmd->tag = p_strdup(cmd->pool, tag);
|
|
|
2c808a |
}
|
|
|
2c808a |
|
|
|
2c808a |
if (cmd->name == NULL) {
|
|
|
2c808a |
- cmd->name = imap_parser_read_word(cmd->parser);
|
|
|
2c808a |
- if (cmd->name == NULL)
|
|
|
2c808a |
+ ret = imap_parser_read_command_name(cmd->parser, &name);
|
|
|
2c808a |
+ if (ret == 0)
|
|
|
2c808a |
return FALSE; /* need more data */
|
|
|
2c808a |
+ if (ret < 0) {
|
|
|
2c808a |
+ client_command_failed_early(&cmd, "Invalid command name.");
|
|
|
2c808a |
+ return TRUE;
|
|
|
2c808a |
+ }
|
|
|
2c808a |
|
|
|
2c808a |
/* UID commands are a special case. better to handle them
|
|
|
2c808a |
here. */
|
|
|
2c808a |
- if (!cmd->uid && strcasecmp(cmd->name, "UID") == 0) {
|
|
|
2c808a |
+ if (!cmd->uid && strcasecmp(name, "UID") == 0) {
|
|
|
2c808a |
cmd->uid = TRUE;
|
|
|
2c808a |
- cmd->name = imap_parser_read_word(cmd->parser);
|
|
|
2c808a |
- if (cmd->name == NULL)
|
|
|
2c808a |
- return FALSE; /* need more data */
|
|
|
2c808a |
+ return client_command_input(cmd);
|
|
|
2c808a |
}
|
|
|
2c808a |
- cmd->name = !cmd->uid ? p_strdup(cmd->pool, cmd->name) :
|
|
|
2c808a |
- p_strconcat(cmd->pool, "UID ", cmd->name, NULL);
|
|
|
2c808a |
+ cmd->name = !cmd->uid ? p_strdup(cmd->pool, name) :
|
|
|
2c808a |
+ p_strconcat(cmd->pool, "UID ", name, NULL);
|
|
|
2c808a |
client_command_init_finished(cmd);
|
|
|
2c808a |
imap_refresh_proctitle();
|
|
|
2c808a |
}
|