[Dovecot] deliver is curious

Nikolai Bochev n.bochev at grandstarco.com
Tue Aug 4 11:48:55 EEST 2009


I've had exactly the same problem. My home folder was a separate
directory under /home/vmail/%d/%n . The mails were in /srv/mail/%d/%n
and i had exactly the same behavior . The error went away when i moved
the home folders under /srv/homes/%d/%n. The weird thing is that if the
user had sieve scripts ( created by Ingo ) the home folders did exist
and everything was fine for that account. However if a user didn't have
a home folder created before a delivery of such email it would fail. I
guess it was some permission issue, but :

root at mail:/usr/src/dovecot-1.2.2# ls -lha / | grep vmail
drwxrwxrwx   8 root  vmail 4.0K 2009-07-13 02:16 home
drwxrwxrwx   5 vmail vmail 4.0K 2009-06-15 10:41 srv
root at mail:/usr/src/dovecot-1.2.2# ls -lha /home | grep vmail
drwxrwxrwx  8 root     vmail    4.0K 2009-07-13 02:16 .
drwxrwxrwx  6 vmail    vmail    4.0K 2009-07-08 17:34 vmail
root at mail:/usr/src/dovecot-1.2.2# 


You can see the difference, but i didn't want to change the ownership
of /home to vmail user. Not sure what i did wrong or what i did right
after that but that's how i fixed it.

On Mon, 2009-08-03 at 01:03 +0200, Sven Strickroth wrote:
> Hi,
> 
> Im' using deliver with postfix (mailbox_command =
> /usr/lib/dovecot/deliver -n -m "$EXTENSION").
> 
> In dovecot.conf I've set mail_location to
> maildir:/var/spool/imap/users/%u/Maildir
> 
> It works, but not for ONE "special" email.
> 
> If I send mail to e.g. th at trg-oha.de it gets correctly delivered (see
> noerror.txt), but I have one mail with an attachment (i cannot provide
> it because of privacy reasons) where i get the attached error.
> 
> How comes that deliver doesn't use the mail_location but the real
> home-directory (from ldap, it doesn't exist on the mailserver) of that
> user in this case?
> 
> plain text document attachment (error.txt)
> Aug  3 00:57:40 mailsrv postfix/qmgr[15624]: 4C8582024C: from=<kt at gmx.de>, size=1436493, nrcpt=1 (queue active)
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): Home dir not found: /home/daten/user/lehrer/th
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): Namespace: type=private, prefix=, sep=., inbox=yes, hidden=no, list=yes, subscriptions=yes
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): maildir: data=/var/spool/imap/users/th/Maildir
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): maildir++: root=/var/spool/imap/users/th/Maildir, index=, control=, inbox=/var/spool/imap/users/th/Maildir
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): Namespace: type=shared, prefix=users.%n., sep=., inbox=no, hidden=no, list=(null), subscriptions=no
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): shared: root=, index=, control=, inbox=
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): Namespace: type=public, prefix=shared., sep=., inbox=no, hidden=no, list=(null), subscriptions=no
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): maildir: data=/var/spool/imap/shared
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): maildir++: root=/var/spool/imap/shared, index=, control=, inbox=
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): Namespace : Using permissions from /var/spool/imap/users/th/Maildir: mode=0700 gid=-1
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): mkdir_parents_chown(/home/daten/user/lehrer/th) failed: Permission denied (euid=2684(th) egid=12(mail) missing +w perm: /home)
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): copy: i_stream_read() failed: Permission denied
> Aug  3 00:57:40 mailsrv dovecot: deliver(th): msgid=<F915DEB780CD459A93FA6A3E9B4564BA at EeeTh>: save failed to INBOX: Internal error occurred. Refer to server log for more information. [2009-08-03 00:57:40]
> Aug  3 00:57:40 mailsrv postfix/local[16289]: 4C8582024C: to=<th at trg-oha.de>, relay=local, delay=45169, delays=45169/0.05/0/0.13, dsn=4.3.0, status=deferred (temporary failure)
> plain text document attachment (noerror.txt)
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): Home dir not found: /home/daten/user/lehrer/th
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): Namespace: type=private, prefix=, sep=., inbox=yes, hidden=no, list=yes, subscriptions=yes
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): maildir: data=/var/spool/imap/users/th/Maildir
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): maildir++: root=/var/spool/imap/users/th/Maildir, index=, control=, inbox=/var/spool/imap/users/th/Maildir
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): Namespace: type=shared, prefix=users.%n., sep=., inbox=no, hidden=no, list=(null), subscriptions=no
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): shared: root=, index=, control=, inbox=
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): Namespace: type=public, prefix=shared., sep=., inbox=no, hidden=no, list=(null), subscriptions=no
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): maildir: data=/var/spool/imap/shared
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): maildir++: root=/var/spool/imap/shared, index=, control=, inbox=
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): Namespace : Using permissions from /var/spool/imap/users/th/Maildir: mode=0700 gid=-1
> Aug  3 00:59:44 mailsrv dovecot: deliver(th): msgid=<4A761B5F.1450503 at tu-clausthal.de>: saved mail to INBOX
> Aug  3 00:59:44 mailsrv postfix/local[16374]: 78E2D20250: to=<th at trg-oha.de>, relay=local, delay=0.07, delays=0.01/0.01/0/0.05, dsn=2.0.0, status=sent (delivered to command: /usr/lib/dovecot/deliver -n -m "$EXTENSION")
> Aug  3 00:59:44 mailsrv postfix/qmgr[15624]: 78E2D20250: removed



More information about the dovecot mailing list