diff options
Diffstat (limited to 'src/imap/cmd-status.c')
-rw-r--r-- | src/imap/cmd-status.c | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/src/imap/cmd-status.c b/src/imap/cmd-status.c new file mode 100644 index 0000000..69c0a51 --- /dev/null +++ b/src/imap/cmd-status.c @@ -0,0 +1,54 @@ +/* Copyright (c) 2002-2018 Dovecot authors, see the included COPYING file */ + +#include "imap-common.h" +#include "imap-resp-code.h" +#include "imap-commands.h" +#include "imap-sync.h" +#include "imap-status.h" + +bool cmd_status(struct client_command_context *cmd) +{ + struct client *client = cmd->client; + const struct imap_arg *args, *list_args; + struct imap_status_items items; + struct imap_status_result result; + struct mail_namespace *ns; + const char *mailbox, *orig_mailbox; + bool selected_mailbox; + + /* <mailbox> <status items> */ + if (!client_read_args(cmd, 2, 0, &args)) + return FALSE; + + if (!imap_arg_get_astring(&args[0], &mailbox) || + !imap_arg_get_list(&args[1], &list_args)) { + client_send_command_error(cmd, "Invalid arguments."); + return TRUE; + } + + /* get the items client wants */ + if (imap_status_parse_items(cmd, list_args, &items) < 0) + return TRUE; + + orig_mailbox = mailbox; + ns = client_find_namespace(cmd, &mailbox); + if (ns == NULL) + return TRUE; + + event_add_str(cmd->global_event, "mailbox", mailbox); + selected_mailbox = client->mailbox != NULL && + mailbox_equals(client->mailbox, ns, mailbox); + if (imap_status_get(cmd, ns, mailbox, &items, &result) < 0) { + client_send_tagline(cmd, result.errstr); + return TRUE; + } + + imap_status_send(client, orig_mailbox, &items, &result); + if (!selected_mailbox) + client_send_tagline(cmd, "OK Status completed."); + else { + client_send_tagline(cmd, "OK ["IMAP_RESP_CODE_CLIENTBUG"] " + "Status on selected mailbox completed."); + } + return TRUE; +} |