master.cf 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136
  1. # inter-mx with postscreen on 25/tcp
  2. smtp inet n - n - 1 postscreen
  3. 10025 inet n - n - 1 postscreen
  4. -o postscreen_upstream_proxy_protocol=haproxy
  5. -o syslog_name=haproxy
  6. smtpd pass - - n - - smtpd
  7. -o smtpd_helo_restrictions=permit_mynetworks,reject_non_fqdn_helo_hostname
  8. -o smtpd_sasl_auth_enable=no
  9. -o smtpd_sender_restrictions=permit_mynetworks,reject_unlisted_sender,reject_unknown_sender_domain
  10. # smtpd tls-wrapped (smtps) on 465/tcp
  11. # TLS protocol can be modified by setting smtps_smtpd_tls_mandatory_protocols in extra.cf
  12. smtps inet n - n - - smtpd
  13. -o smtpd_tls_wrappermode=yes
  14. -o smtpd_client_restrictions=permit_mynetworks,permit_sasl_authenticated,reject
  15. -o smtpd_tls_mandatory_protocols=$smtps_smtpd_tls_mandatory_protocols
  16. -o tls_preempt_cipherlist=yes
  17. -o syslog_name=postfix/smtps
  18. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  19. 10465 inet n - n - - smtpd
  20. -o smtpd_upstream_proxy_protocol=haproxy
  21. -o smtpd_tls_wrappermode=yes
  22. -o smtpd_client_restrictions=permit_mynetworks,permit_sasl_authenticated,reject
  23. -o smtpd_tls_mandatory_protocols=$smtps_smtpd_tls_mandatory_protocols
  24. -o tls_preempt_cipherlist=yes
  25. -o syslog_name=postfix/smtps-haproxy
  26. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  27. # smtpd with starttls on 587/tcp
  28. # TLS protocol can be modified by setting submission_smtpd_tls_mandatory_protocols in extra.cf
  29. submission inet n - n - - smtpd
  30. -o smtpd_client_restrictions=permit_mynetworks,permit_sasl_authenticated,reject
  31. -o smtpd_enforce_tls=yes
  32. -o smtpd_tls_security_level=encrypt
  33. -o smtpd_tls_mandatory_protocols=$submission_smtpd_tls_mandatory_protocols
  34. -o tls_preempt_cipherlist=yes
  35. -o syslog_name=postfix/submission
  36. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  37. 10587 inet n - n - - smtpd
  38. -o smtpd_upstream_proxy_protocol=haproxy
  39. -o smtpd_client_restrictions=permit_mynetworks,permit_sasl_authenticated,reject
  40. -o smtpd_enforce_tls=yes
  41. -o smtpd_tls_security_level=encrypt
  42. -o smtpd_tls_mandatory_protocols=$submission_smtpd_tls_mandatory_protocols
  43. -o tls_preempt_cipherlist=yes
  44. -o syslog_name=postfix/submission-haproxy
  45. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  46. # used by SOGo
  47. # smtpd_sender_restrictions should match main.cf, but with check_sasl_access prepended for login-as-mailbox-user function
  48. 588 inet n - n - - smtpd
  49. -o smtpd_client_restrictions=permit_mynetworks,permit_sasl_authenticated,reject
  50. -o smtpd_tls_auth_only=no
  51. -o smtpd_sender_restrictions=check_sasl_access,regexp:/opt/postfix/conf/allow_mailcow_local.regexp,reject_authenticated_sender_login_mismatch,permit_mynetworks,permit_sasl_authenticated,reject_unlisted_sender,reject_unknown_sender_domain
  52. -o syslog_name=postfix/sogo
  53. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  54. # used to reinject quarantine mails
  55. 590 inet n - n - - smtpd
  56. -o smtpd_helo_restrictions=
  57. -o smtpd_client_restrictions=permit_mynetworks,reject
  58. -o smtpd_tls_auth_only=no
  59. -o smtpd_milters=
  60. -o non_smtpd_milters=
  61. -o syslog_name=postfix/quarantine
  62. -o smtpd_end_of_data_restrictions=$smtpd_last_auth
  63. # enforced smtp connector
  64. smtp_enforced_tls unix - - n - - smtp
  65. -o smtp_tls_security_level=encrypt
  66. -o syslog_name=enforced-tls-smtp
  67. -o smtp_delivery_status_filter=pcre:/opt/postfix/conf/smtp_dsn_filter
  68. # smtp connector used, when a transport map matched
  69. # this helps to have different sasl maps than we have with sender dependent transport maps
  70. smtp_via_transport_maps unix - - n - - smtp
  71. -o smtp_sasl_password_maps=proxy:mysql:/opt/postfix/conf/sql/mysql_sasl_passwd_maps_transport_maps.cf
  72. tlsproxy unix - - n - 0 tlsproxy
  73. dnsblog unix - - n - 0 dnsblog
  74. pickup fifo n - n 60 1 pickup
  75. cleanup unix n - n - 0 cleanup
  76. qmgr fifo n - n 300 1 qmgr
  77. tlsmgr unix - - n 1000? 1 tlsmgr
  78. rewrite unix - - n - - trivial-rewrite
  79. bounce unix - - n - 0 bounce
  80. defer unix - - n - 0 bounce
  81. trace unix - - n - 0 bounce
  82. verify unix - - n - 1 verify
  83. flush unix n - n 1000? 0 flush
  84. proxymap unix - - n - - proxymap
  85. proxywrite unix - - n - 1 proxymap
  86. smtp unix - - n - - smtp
  87. relay unix - - n - - smtp
  88. showq unix n - n - - showq
  89. error unix - - n - - error
  90. retry unix - - n - - error
  91. discard unix - - n - - discard
  92. local unix - n n - - local
  93. virtual unix - n n - - virtual
  94. lmtp unix - - n - - lmtp
  95. anvil unix - - n - 1 anvil
  96. scache unix - - n - 1 scache
  97. maildrop unix - n n - - pipe flags=DRhu
  98. user=vmail argv=/usr/bin/maildrop -d ${recipient}
  99. # start whitelist_fwd
  100. 127.0.0.1:10027 inet n n n - 0 spawn user=nobody argv=/usr/local/bin/whitelist_forwardinghosts.sh
  101. 127.0.0.1:10028 inet n n n - 0 spawn user=nobody argv=/usr/local/bin/smtpd_last_login.sh
  102. # end whitelist_fwd
  103. # start watchdog-specific
  104. # logs to local7 (hidden)
  105. 589 inet n - n - - smtpd
  106. -o smtpd_client_restrictions=permit_mynetworks,reject
  107. -o syslog_name=watchdog
  108. -o syslog_facility=local7
  109. -o smtpd_milters=
  110. -o cleanup_service_name=watchdog_cleanup
  111. -o non_smtpd_milters=
  112. watchdog_cleanup unix n - n - 0 cleanup
  113. -o syslog_name=watchdog
  114. -o syslog_facility=local7
  115. -o queue_service_name=watchdog_qmgr
  116. watchdog_qmgr fifo n - n 300 1 qmgr
  117. -o syslog_facility=local7
  118. -o syslog_name=watchdog
  119. -o rewrite_service_name=watchdog_rewrite
  120. watchdog_rewrite unix - - n - - trivial-rewrite
  121. -o syslog_facility=local7
  122. -o syslog_name=watchdog
  123. -o local_transport=watchdog_discard
  124. watchdog_discard unix - - n - - discard
  125. -o syslog_facility=local7
  126. -o syslog_name=watchdog
  127. # end watchdog-specific