
O que estou tentando conseguir é que qualquer e-mail recebido [email protected]
seja reescrito [email protected]
e entregue em [email protected]
.
Ambos canonical_maps
e virtual_alias_maps
trabalham para entrega ao destinatário alternativo. Quando li odocumentoisso me diz que com o canonical_maps
, cleanup
faz uma reescrita completa.
Porém, na prática, o e-mail ainda possui o to
nome do destinatário original. Então, ao olhar o e-mail na caixa de correio de Bob, ele mostra um e-mail para Joe.
De alguma forma, sinto que estou faltando alguma coisa aqui.
Configuração:
alias_database = hash:/etc/aliases
alias_maps = hash:/etc/aliases
append_dot_mydomain = no
biff = no
bounce_queue_lifetime = 2d
canonical_maps = hash:/etc/postfix/canonical
config_directory = /etc/postfix
header_checks = pcre:/etc/postfix/header_checks
home_mailbox = Maildir/
html_directory = /usr/share/doc/postfix/html
inet_interfaces = all
mailbox_size_limit = 0
maximal_queue_lifetime = 4d
milter_default_action = accept
milter_protocol = 2
mydestination = ...
myhostname = ...
mynetworks = ...
myorigin = /etc/mailname
non_smtpd_milters = inet:localhost:8891
readme_directory = /usr/share/doc/postfix
recipient_delimiter = +
relayhost =
smtp_fallback_relay = ...
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache
smtpd_banner = $myhostname ESMTP $mail_name
smtpd_milters = inet:localhost:8891
smtpd_recipient_restrictions = check_recipient_access hash:/etc/postfix/recipient_access permit_mynetworks reject_unauth_destination
smtpd_tls_cert_file = /etc/ssl/certs/ssl-cert-snakeoil.pem
smtpd_tls_key_file = /etc/ssl/private/ssl-cert-snakeoil.key
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache
smtpd_use_tls = yes
transport_maps = hash:/etc/postfix/transport
virtual_alias_maps = hash:/etc/postfix/virtual
Histórico:
Sep 25 09:40:30 server1 postfix/smtpd[28285]: connect from mail-la0-f66.google.com[209.85.215.66]
Sep 25 09:40:31 server1 postfix/smtpd[28285]: 7CA784EDB6: client=mail-la0-f66.google.com[209.85.215.66]
Sep 25 09:40:31 server1 postfix/cleanup[28339]: 7CA784EDB6: message-id=<CAJjncucnGM532xhcn37VAwmwQoYEwOUfE_A33-oyJJH5PqPUcA@mail.gmail.com>
Sep 25 09:40:31 server1 postfix/qmgr[7593]: 7CA784EDB6: from=<[email protected]>, size=1813, nrcpt=1 (queue active)
Sep 25 09:40:32 server1 postfix/smtpd[28285]: disconnect from mail-la0-f66.google.com[209.85.215.66]
Sep 25 09:40:32 server1 postfix/smtp[28593]: 7CA784EDB6: enabling PIX workarounds: disable_esmtp delay_dotcrlf for ...[...]]:25
Sep 25 09:40:33 server1 postfix/smtp[28593]: 7CA784EDB6: to=<[email protected]>, orig_to=<[email protected]>, relay=...[...]:25, delay=1.6, delays=0.45/0/0.42/0.73, dsn=2.0.0, status=sent (250 2.0.0 Ok: queued as 98F729600E)
Sep 25 09:40:33 server1 postfix/qmgr[7593]: 7CA784EDB6: removed
Responder1
No mail.log, parece que você deseja reescrever o email do cliente remoto. A configuração padrão de reescrita do postfix evita que isso aconteça.
Trecho deREADME de reescrita de postfix
As versões 2.2 do Postfix oferecem a opção de não reescrever os cabeçalhos das mensagens de clientes SMTP remotos ou de rotular endereços incompletos nesses cabeçalhos de mensagens como inválidos. Veja como funciona:
O Postfix sempre reescreve cabeçalhos de mensagens de clientes SMTP locais e do comando sendmail do Postfix e anexa seu próprio domínio a endereços incompletos. O
local_header_rewrite_clients
parâmetro controla quais clientes SMTP o Postfix considera locais (por padrão, apenas endereços de interface de rede local).O Postfix nunca reescreve endereços de cabeçalho de mensagens de clientes SMTP remotos quando o
remote_header_rewrite_domain
valor do parâmetro está vazio (a configuração padrão).Caso contrário, o Postfix reescreve os cabeçalhos das mensagens de clientes SMTP remotos e anexa o
remote_header_rewrite_domain
valor aos endereços incompletos. Este recurso pode ser usado para anexar um domínio reservado como "domínio.inválido", para que endereços incompletos não possam ser confundidos com endereços locais.
Portanto, a solução mais simples é não deixar o parâmetro remote_header_rewrite_domain
com valor vazio. Você precisa fornecer valor a este parâmetro com valores como
remote_header_rewrite_domain = domain.invalid
Ou você pode usar static:all
o parâmetro on local_header_rewrite_clients
para que o postfix considere todos os clientes remotos como locais.
local_header_rewrite_clients = static:all