From eef36633df93c3ef852980725e3697ae07a723aa Mon Sep 17 00:00:00 2001 From: InterLinked1 <24227567+InterLinked1@users.noreply.github.com> Date: Sun, 19 Nov 2023 16:21:35 -0500 Subject: [PATCH] net_imap: Strip quotes for SUBSCRIBE command. Failing to strip quotes led to including quotes directly in file path operations; add missing macro calls where they were missing. --- nets/net_imap.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/nets/net_imap.c b/nets/net_imap.c index 6904539c..d4a5d06a 100644 --- a/nets/net_imap.c +++ b/nets/net_imap.c @@ -4414,15 +4414,19 @@ static int imap_process(struct imap_session *imap, char *s) } else if (!strcasecmp(command, "SUBSCRIBE")) { char fullmaildir[256]; int myacl; + REQUIRE_ARGS(s); + STRIP_QUOTES(s); IMAP_NO_READONLY(imap); /* Since we don't check for mailbox existence (and everything is always subscribed anyways), no real need to check ACLs here */ - bbs_debug(1, "Ignoring sbscription attempt for %s for mailbox %d\n", S_IF(s), mailbox_id(imap->mbox)); + bbs_debug(1, "Ignoring subscription attempt for %s for mailbox %d\n", S_IF(s), mailbox_id(imap->mbox)); imap_reply(imap, "OK SUBSCRIBE completed"); /* Everything available is already subscribed anyways, so can't hurt */ imap_translate_dir(imap, s, fullmaildir, sizeof(fullmaildir), &myacl); mailbox_dispatch_event_basic(EVENT_MAILBOX_SUBSCRIBE, imap->node, imap->mbox, fullmaildir); } else if (!strcasecmp(command, "UNSUBSCRIBE")) { char fullmaildir[256]; int myacl; + REQUIRE_ARGS(s); + STRIP_QUOTES(s); IMAP_NO_READONLY(imap); bbs_warning("Unsubscription attempt for %s for mailbox %d\n", S_IF(s), mailbox_id(imap->mbox)); imap_reply(imap, "NO [NOPERM] Permission denied");