Назад | Перейти на главную страницу

Тегирование адресов электронной почты не работает с виртуальными почтовыми ящиками в postfix

У меня есть собственный почтовый сервер, и я хотел бы иметь возможность использовать динамическую пометку адресов электронной почты. Я добавил recipient_delimiter = +- директиве к моей конфигурации и перезапуску postfix, но теперь, если я напишу bob+sometaghere@starbeamrainbowlabs.com например, письмо будет возвращено с ошибкой «Неизвестный пользователь». Если я напишу unknownuser@starbeamrainbowlabs.com, письмо будет доставлено webmaster счет, как ожидалось.

Вот моя конфигурация постфикса:

## These are all default Postfix settings that we won't change
alias_maps = hash:/etc/aliases
alias_database = hash:/etc/aliases
append_dot_mydomain = no
biff = no
broken_sasl_auth_clients = yes
inet_interfaces = all
mailbox_command = /usr/lib/dovecot/deliver -c
    /etc/dovecot/conf.d/01-mail-stack-delivery.conf -m "${EXTENSION}"
mailbox_size_limit = 0
myorigin = /etc/mailname
readme_directory = no
recipient_delimiter = +-
relayhost =
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
smtpd_sasl_auth_enable = yes
smtpd_sasl_authenticated_header = yes
smtpd_sasl_path = private/dovecot-auth
smtpd_sasl_security_options = noanonymous
smtpd_sasl_local_domain = $myhostname
smtpd_sasl_type = dovecot
smtpd_tls_auth_only = yes
smtpd_tls_received_header = yes
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
tls_random_source = dev:/dev/urandom

## Settings below this line are things we're modifying or adding

## Your mail server identity options
myhostname = mail.starbeamrainbowlabs.com
#mydestination = localhost, starbeamrainbowlabs.com,
#    localhost.starbeamrainbowalabs.com
# 89.107.190.141 = cross-code central
mynetworks = 127.0.0.0/8 192.168.0.0/24 [::ffff:127.0.0.0]/104 [::1]/128 89.107.190.141

## Customized smtpd paramters
smtpd_banner = $myhostname ESMTP
smtpd_helo_required = yes
smtpd_helo_restrictions = permit_mynetworks,
    check_helo_access hash:/etc/postfix/helo_access
    #reject_non_fqdn_helo_hostname,
    reject_invalid_helo_hostname,
    #reject_unknown_helo_hostname,
    #warn_if_reject, # warn us instead of actually blocking them
    permit
smtpd_sender_restrictions = permit_mynetworks,
    permit_sasl_authenticated,
    #reject_unknown_sender_domain,
    reject_sender_login_mismatch
smtpd_recipient_restrictions = permit_mynetworks,
    permit_sasl_authenticated,
    reject_unknown_client_hostname,
    reject_unknown_sender_domain,
    reject_unknown_recipient_domain,
    reject_unauth_pipelining,
    reject_unauth_destination, 
    reject_invalid_hostname,
    reject_non_fqdn_sender
smtpd_sender_login_maps = $virtual_mailbox_maps

## Dealing with rejection: use permanent 550 errors to stop retries
unknown_address_reject_code = 550
unknown_hostname_reject_code = 550
unknown_client_reject_code = 550

## customized TLS parameters
smtpd_tls_ask_ccert = yes
smtpd_tls_cert_file = /etc/ssl/private/chain/www-mail.starbeamrainbowlabs.com.pem
smtpd_tls_key_file = /etc/ssl/private/key/decrypted/www-mail.starbeamrainbowlabs.com.key
smtpd_tls_CAfile = /etc/ssl/certs/ca-certificates.crt
smtpd_tls_ciphers = high
smtpd_tls_loglevel = 1
smtpd_tls_security_level = may
smtpd_tls_session_cache_timeout = 3600s


## Customized Dovecot and virtual user-specific settings
canonical_maps = hash:/etc/postfix/canonical
home_mailbox = Maildir/
message_size_limit = 104857600
virtual_alias_maps = hash:/etc/postfix/virtual
virtual_mailbox_domains = hash:/etc/postfix/virtual-mailbox-domains
virtual_mailbox_maps = hash:/etc/postfix/virtual-mailbox-users
virtual_transport = dovecot

## This setting will generate an error if you restart Postfix before
## adding the appropriate service definition in master.cf, so make
## sure to get that taken care of!
dovecot_destination_recipient_limit = 1

## Customized milter settings
milter_default_action = accept
milter_connect_macros = j {daemon_name} v {if_name} _
non_smtpd_milters = $smtpd_milters
smtpd_milters = inet:127.0.0.1:11444 unix:/opendkim/opendkim.sock

## Other customized mail server settings
default_destination_concurrency_limit = 5
disable_vrfy_command = yes
relay_destination_concurrency_limit = 1
smtp_tls_note_starttls_offer = yes
smtp_tls_security_level = may

Из /etc/postfix/master.cf, У меня есть это определение Dovecot:

dovecot   unix  -       n       n       -       -       pipe
  flags=DRhu user=vmail:vmail argv=/usr/lib/dovecot/deliver
  -f ${sender} -d ${recipient}

У меня также есть определения для ifmail, bsmtp, scalemail-backend, mailman, uucp, scache, maildrop, и куча других, но я не совсем уверен, что они все делают.

Кто-нибудь знает, что здесь происходит и как я могу это исправить, пожалуйста?

Я использую виртуальные почтовые ящики.

В /etc/postfix/master.cf файл конфигурации, убедитесь, что определение dovecot сервис, на который ссылается virtual_transport параметр конфигурации, установлен, чтобы подавить добавочную часть адреса получателя во время вызова /usr/lib/dovecot/deliver.

Например, это может не сработать, потому что ${recipient} будет расширен до bob+sometaghere@starbeamrainbowlabs.com от Postfix труба (8) служба:

dovecot   unix  -       n       n       -       -       pipe
  flags=DRhu user=dovecot:dovecot argv=/usr/lib/dovecot/deliver -f ${sender} -d ${recipient}

В ${recipient} макрос следует заменить на ${user}@${domain} в этом сценарии, чтобы агент доставки Dovecot получил правильный адрес bob@starbeamrainbowlabs.com в командной строке:

dovecot   unix  -       n       n       -       -       pipe
  flags=DRhu user=dovecot:dovecot argv=/usr/lib/dovecot/deliver -f ${sender} -d ${user}@${domain}

Ссылка: https://wiki1.dovecot.org/LDA/Postfix

Несколько символов в recipient_delimiter кажется, что параметр поддерживается только в Postfix 2.11 или новее. Убедитесь, что вы используете последнюю версию Postfix или, в качестве альтернативы, используете только один символ-разделитель.

Из postconf (5) страница руководства:

recipient_delimiter (по умолчанию: пусто)

Набор символов, которые могут отделять имя пользователя от его расширения (пример: user + foo) или имя файла .forward от его расширения (пример: .forward + foo). Обычно программа пытается использовать user + foo и .forward + foo перед тем, как попробовать user и .forward. Эта реализация распознает один символ-разделитель и одно расширение для каждого адреса электронной почты или имени файла .forward.

Когда набор recipient_delimiter содержит несколько символов (Postfix 2.11 и новее), имя пользователя или имя файла .forward отделяется от его расширения первым символом, который соответствует набору recipient_delimiter.