Why did you leave the prefix uncommented? Also you already have maildir++ folders virtual.all and virtual.flagged, they are not related to this, and you should remove them.
uncomment the prefix, and you'll see virtual.All and virtual.Flagged folders. Aki > On 31/01/2022 23:04 A B <alex.bry...@trancos.com> wrote: > > > Thank you Aki. > > I have updated as you suggested: > > 10-mail.conf > namespace virtual { > location = > virtual:/etc/dovecot/virtual:INDEX=~/.virtual:CONTROL=~/.virtual:VOLATILEDIR=~/.virtual/ > type = private > #prefix = virtual. > separator = . > } > > I manually added the directory structure and files: > [dovecot]# ll > total 32 > drwxr-xr-x. 5 root root 121 Jan 31 14:41 ./ > drwxr-xr-x. 115 root root 8192 Jan 31 11:05 ../ > drwxr-xr-x. 3 root root 57 Jan 7 10:27 bak/ > drwxr-xr-x. 2 root root 4096 Jan 25 15:05 conf.d/ > -rw-r--r--. 1 root root 2658 Jan 25 16:52 dovecot.conf > -rw-r--r--. 1 root root 4391 Oct 8 2019 dovecot.conf-backup > -rw-r-----. 1 root dovecot 280 Jan 25 10:41 dovecot-sql.conf.ext > drwxr-xr-x. 4 root root 32 Jan 31 14:41 virtual/ > [dovecot]# ll virtual/ > total 0 > drwxr-xr-x. 4 root root 32 Jan 31 14:41 ./ > drwxr-xr-x. 5 root root 121 Jan 31 14:41 ../ > drwxr-xr-x. 2 root root 29 Jan 31 14:41 All/ > drwxr-xr-x. 2 root root 29 Jan 31 14:41 Flagged/ > [dovecot]# ll virtual/All/ > total 4 > drwxr-xr-x. 2 root root 29 Jan 31 14:41 ./ > drwxr-xr-x. 4 root root 32 Jan 31 14:41 ../ > -rw-r--r--. 1 root root 10 Jan 31 14:31 dovecot-virtual > []# cat virtual/All/dovecot-virtual > * > all > > I restarted the dovecot service. When I request to see the emails in the > virtual "All" folder (e.g. virtual.All), just like I would do with say the > Inbox or Trash folder, the virtual* folder gets created in the user > directory, but no emails are "found" or returned. > > [Maildir]# pwd > /home/vmail/example.com/user.name/Maildir > (http://example.com/user.name/Maildir) > [Maildir]# ll > total 80 > drwxrwx---. 20 vmail vmail 4096 Jan 31 14:31 ./ > drwxrwx---. 4 vmail vmail 37 Jan 31 14:19 ../ > drwxrwx---. 5 vmail vmail 135 Jan 25 11:26 .Archive/ > drwx------. 2 vmail vmail 4096 Jan 31 14:28 cur/ > -rw-rw----. 1 vmail vmail 896 Jan 25 17:10 dovecot.index > -rw-rw----. 1 vmail vmail 22596 Jan 31 14:01 dovecot.index.cache > -rw-rw----. 1 vmail vmail 11160 Jan 31 14:28 dovecot.index.log > -rw-rw----. 1 vmail vmail 1896 Jan 28 17:15 dovecot.list.index > -rw-rw----. 1 vmail vmail 7752 Jan 31 14:36 dovecot.list.index.log > -rw-rw----. 1 vmail vmail 384 Jan 25 15:32 dovecot.mailbox.log > -rw-rw----. 1 vmail vmail 1887 Jan 25 11:35 dovecot-uidlist > -rw-rw----. 1 vmail vmail 8 Jan 31 14:31 dovecot-uidvalidity > -r--r--r--. 1 vmail vmail 0 Jan 24 16:35 dovecot-uidvalidity.61ef29a3 > drwxrwx---. 5 vmail vmail 183 Jan 28 17:22 .Drafts/ > drwxrwx---. 5 vmail vmail 135 Jan 25 11:24 .Junk/ > -rw-rw----. 1 vmail vmail 1130 Jan 28 17:37 maildirsize > drwx------. 2 vmail vmail 6 Jan 25 11:34 new/ > drwxrwx---. 5 vmail vmail 135 Jan 31 04:29 .Sent/ > drwxrwx---. 5 vmail vmail 135 Jan 25 10:51 '.Sent Messages'/ > -rw-rw----. 1 vmail vmail 43 Jan 25 10:50 subscriptions > drwx------. 2 vmail vmail 6 Jan 25 11:35 tmp/ > drwxrwx---. 5 vmail vmail 135 Jan 25 13:23 .Trash/ > drwxrwx---. 5 vmail vmail 135 Jan 31 14:36 .virtual.All/ > drwxrwx---. 5 vmail vmail 135 Jan 31 14:28 .virtual.Flagged/ > [Maildir]ll .virtual.All/ > total 16 > drwxrwx---. 5 vmail vmail 135 Jan 31 14:36 ./ > drwxrwx---. 20 vmail vmail 4096 Jan 31 14:31 ../ > drwxrwx---. 2 vmail vmail 6 Jan 31 14:31 cur/ > -rw-rw----. 1 vmail vmail 868 Jan 31 14:31 dovecot.index.cache > -rw-rw----. 1 vmail vmail 472 Jan 31 14:36 dovecot.index.log > -rw-rw----. 1 vmail vmail 51 Jan 31 14:36 dovecot-uidlist > -rw-rw----. 1 vmail vmail 0 Jan 31 14:31 maildirfolder > drwxrwx---. 2 vmail vmail 6 Jan 31 14:31 new/ > drwxrwx---. 2 vmail vmail 6 Jan 31 14:31 tmp/ > > Any suggestions what I should work on next to troubleshoot? Again, my goal is > to be able to "fetch" all emails with the virtual.All, and all "flagged" > emails with virtual.Flagged. > > Thank you. > > > > --- > []# doveconf -n > # 2.3.8 (9df20d2db): /etc/dovecot/dovecot.conf > # OS: Linux 4.18.0-348.2.1.el8_5.x86_64 x86_64 CentOS Linux release 8.5.2111 > xfs > # Hostname: example.com (http://example.com) > auth_debug = yes > auth_verbose = yes > auth_verbose_passwords = yes > first_valid_uid = 1000 > lda_mailbox_autocreate = yes > log_timestamp = "%Y-%m-%d %H:%M:%S " > mail_location = maildir:/home/vmail/%d/%n/Maildir > mail_plugins = " quota" > mbox_write_locks = fcntl > namespace inbox { > inbox = yes > location = > mailbox Archive { > auto = subscribe > special_use = \Archive > } > mailbox Drafts { > auto = subscribe > special_use = \Drafts > } > mailbox Junk { > auto = subscribe > special_use = \Junk > } > mailbox Sent { > auto = subscribe > special_use = \Sent > } > mailbox "Sent Messages" { > auto = subscribe > special_use = \Sent > } > mailbox Trash { > auto = subscribe > special_use = \Trash > } > mailbox virtual.All { > auto = subscribe > comment = All my messages > special_use = \All > } > mailbox virtual.Flagged { > auto = subscribe > comment = All my flagged messages > special_use = \Flagged > } > prefix = INBOX. > separator = . > type = private > } > namespace virtual { > location = > virtual:/etc/dovecot/virtual:INDEX=~/.virtual:CONTROL=~/.virtual:VOLATILEDIR=~/.virtual/ > prefix = > separator = . > type = private > } > passdb { > args = /etc/dovecot/dovecot-sql.conf.ext > driver = sql > } > passdb { > driver = pam > } > plugin { > quota = maildir:User quota > quota_grace = 10%% > quota_max_mail_size = 30M > quota_rule = *:storage=100M > quota_rule2 = INBOX.Trash:storage=+10M > quota_status_nouser = DUNNO > quota_status_overquota = 552 5.2.2 Mailbox is full > quota_status_success = DUNNO > } > protocols = imap pop3 > service auth-worker { > user = root > } > service auth { > unix_listener /var/spool/postfix/private/auth { > group = postfix > mode = 0666 > user = postfix > } > unix_listener auth-master { > mode = 0600 > user = vmail > } > unix_listener auth-userdb { > mode = 0600 > user = vmail > } > user = dovecot > } > service imap-login { > inet_listener imaps { > port = 993 > ssl = yes > } > } > service pop3-login { > inet_listener pop3s { > port = 995 > ssl = yes > } > } > service quota-status { > client_limit = 1 > executable = quota-status -p postfix > inet_listener { > port = 12340 > } > } > service stats { > unix_listener stats-reader { > group = vmail > mode = 0660 > user = vmail > } > unix_listener stats-writer { > group = vmail > mode = 0660 > user = vmail > } > } > ssl = required > ssl_cert = </etc/letsencrypt/live/example.com/fullchain.pem > (http://example.com/fullchain.pem) > ssl_cipher_list = PROFILE=SYSTEM > ssl_key = # hidden, use -P to show it > userdb { > args = uid=5000 gid=5000 home=/home/vmail/%d/%n allow_all_users=yes > driver = static > } > userdb { > driver = passwd > } > protocol lda { > auth_socket_path = /var/run/dovecot/auth-master > log_path = /home/vmail/dovecot-deliver.log > postmaster_address = postmas...@example.com > } > protocol pop3 { > pop3_uidl_format = %08Xu%08Xv > } > protocol imap { > mail_plugins = " quota imap_quota virtual" > } > > > > On Mon, Jan 31, 2022 at 12:30 AM Aki Tuomi <aki.tu...@open-xchange.com> wrote: > > > > > On 26/01/2022 19:48 A B <alex.bry...@trancos.com> wrote: > > > > > > > > > Hello, > > > > > > I'm trying to use the virtual "All" and "Flagged" mailboxes as described > > in 15-mailboxes.conf. > > > > > > The information here > > (https://doc.dovecot.org/configuration_manual/virtual_plugin/) doesn't > > really touch on how to actually interact with the virtual mailboxes. > > > > > > My presumption is that when I mark an email message in the Inbox as > > FLAGGED (and I can confirm the \Flagged flag has been set) then I should > > then be able to either (1) see a copy of that message in the > > virtual.Flagged folder, or (2) when I use an imap command to get the > > message nums or whatever from the virtual.Flagged folder/mailbox, it should > > return the message that is flagged in the inbox as a result. > > > > > > Additionally, I'm presuming that for each new user that automatically > > gets added, I would have to create my own script that would add the > > dovecot-virtual file, dovecot doesn't do that on its own. > > > > > > When I view the user's directory I see these folders were created: > > > --- > > > > <snip/> > > > > You usually use these global virtual folders like this: > > > > namespace virtual { > > location = > > virtual:/etc/dovecot/virtual:INDEX=~/.virtual:CONTROL=~/.virtual:VOLATILEDIR=~/.virtual/ > > ... rest of the settings > > } > > > > > > Then you create the dovecot-virtual files under /etc/dovecot/virtual like > > > > /etc/dovecot/virtual/Flagged/dovecot-virtual > > > > This lets you creat them automatically for all users. > > > > Aki > >