Dovecot cria pasta, Postfix espera arquivo

6

Eu tentei configurar um combo Postfix / Dovecot com usuários virtuais usando este guia .

Meu servidor está executando o Postfix 2.6.6 e o Dovecot 2.0.9 no CentOS 6.5.

O problema é que, quando me conecto ao servidor usando o Outlook 2013 (ele se conecta muito bem ao IMAP + SMTP) e envio para mim mesmo um e-mail de teste, não recebo o e-mail. Olhando para o maillog eu posso ver que estou recebendo o erro

postfix/virtual[2768]: 9C3D480768: to=<[email protected]>, relay=virtual, delay=1132, delays=1132/0.02/0/0.02, dsn=4.2.0, status=deferred (delivery failed to mailbox /var/vmail/domain.net/user: cannot open file: Is a directory)

A mensagem de erro foi bem clara e eu pensei, bem, isso poderia ser sobras de uma instalação defeituosa do Cyrus / Postfix que eu tinha anteriormente. Eu fui em frente e deletei a pasta do vmail, criei uma subpasta para o domínio e mudei a propriedade de tudo para o vmail: vmail. Eu reinicio o postfix e dovecot e o diretório da caixa de entrada aparece novamente. O postfix continua a reclamar como antes. Então eu tentei apagar a pasta e depois criar um arquivo vazio, mas isso só fez um problema de dovecot em vez de um problema de postfix, então agora a dovecot diz que estava esperando um arquivo em vez de um diretório.

/etc/postfix/main.cf

queue_directory = /var/spool/postfix
command_directory = /usr/sbin
daemon_directory = /usr/libexec/postfix
data_directory = /var/lib/postfix
mail_owner = postfix
unknown_local_recipient_reject_code = 550
alias_maps = hash:/etc/postfix/aliases
alias_database = $alias_maps

inet_interfaces = all
inet_protocols = ipv4
mydestination = $myhostname, localhost.$mydomain, localhost

debug_peer_level = 2
debugger_command =
         PATH=/bin:/usr/bin:/usr/local/bin:/usr/X11R6/bin
         ddd $daemon_directory/$process_name $process_id & sleep 5

sendmail_path = /usr/sbin/sendmail.postfix
newaliases_path = /usr/bin/newaliases.postfix
mailq_path = /usr/bin/mailq.postfix
setgid_group = postdrop
html_directory = no
manpage_directory = /usr/share/man
sample_directory = /usr/share/doc/postfix-2.6.6/samples
readme_directory = /usr/share/doc/postfix-2.6.6/README_FILES

relay_domains = *
virtual_alias_maps=hash:/etc/postfix/vmail_aliases
virtual_mailbox_domains=hash:/etc/postfix/vmail_domains
virtual_mailbox_maps=hash:/etc/postfix/vmail_mailbox

virtual_mailbox_base = /var/vmail
virtual_minimum_uid = 2222
virtual_transport = virtual
virtual_uid_maps = static:2222
virtual_gid_maps = static:2222

smtpd_sasl_auth_enable = yes
smtpd_sasl_type = dovecot
smtpd_sasl_path = /var/run/dovecot/auth-client
smtpd_sasl_security_options = noanonymous
smtpd_sasl_tls_security_options = $smtpd_sasl_security_options
smtpd_sasl_local_domain = $mydomain
broken_sasl_auth_clients = yes

smtpd_recipient_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination
smtpd_relay_restrictions = permit_mynetworks, permit_sasl_authenticated, reject_unauth_destination

/etc/dovecot/dovecot.conf

listen = *
ssl = no
protocols = imap lmtp
disable_plaintext_auth = no
auth_mechanisms = plain login
mail_access_groups = vmail
default_login_user = vmail
first_valid_uid = 2222
first_valid_gid = 2222
mail_location = maildir:/var/vmail/%d/%n

passdb {
    driver = passwd-file
    args = scheme=SHA1 /etc/dovecot/passwd
}
userdb {
    driver = static
    args = uid=2222 gid=2222 home=/var/vmail/%d/%n allow_all_users=yes
}
service auth {
    unix_listener auth-client {
        group = postfix
        mode = 0660
        user = postfix
    }
    user = root
}
service imap-login {
    process_min_avail = 1
    user = vmail
}

e, finalmente, algumas entradas de exemplo em meus domínios / aliases / listas de caixas de correio

domain.tld        OK # /etc/postfix/vmail_domains
[email protected]   domain.tld/user # /etc/postfix/vmail_mailbox
[email protected]   [email protected] # /etc/postfix/vmail_aliases
[email protected]:oOeIaLM/TyEPOdflb+GlL7d1MhE= # /etc/dovecot/passwd
    
por Time Sheep 06.03.2014 / 15:07

1 resposta

12

A resposta é extremamente simples. O caminho em /etc/postfix/vmail_mailbox está faltando uma barra à direita. Quando não houver nenhuma barra no final, o postfix irá tratá-la como um arquivo e, assim, assumir que a caixa de correio está no formato Mailbox (e não Maildir).

Ao anexar a barra final, o postfix considerará corretamente o diretório como sendo do formato maildir e o tratará de acordo.

Exemplo:

[email protected]   domain.tld/user/
[email protected]   domain.tld/user2/
    
por 06.03.2014 / 15:43