dnl dnl использование mailertable для выбора транспорта и маршрута для доставки сообщений dnl NO - не использовать mailertable для выбора транспорта и маршрута для доставки сообщений dnl TEXT - использовать отсылку по mailertable в виде текстового файла dnl DBM - использовать отсылку по mailertable в виде DBM файла dnl MYSQL - использовать отсылку по mailertable в виде таблицы в базе данных MYSQL dnl SQLITE - использовать mailertable в виде таблицы в БД SQLite dnl define(`confMAILERTABLE', `NO')dnl dnl dnl при указании TEXT или DBM в confMAILERTABLE маршруты доставки почты dnl прописываются в CONFDIR/mailertable в виде: dnl домен : тип_транспорта : маршрут_1 : маршрут_2 : ... : маршрут_N dnl dnl в качестве типов транспорта могут быть указаны: dnl local - доставка почты домена в локальный mailbox dnl virt - доставка почты домена в mailbox в виртуальном домене dnl uucp-dom - доставка почты домена в uucp mailbox dnl smtp - доставка почты домена по smtp по маршруту dnl lmtp - доставка почты домена по lmtp по маршруту dnl lmtpunix - доставка почты домена по lmtp через UNIX domain socket dnl dnl для smtp и lmtp транспортов: dnl - в качестве маршрута можно указывать имена хостов, а также названия dnl доменов с суффиксами /MX и /bestMX (для использования суффикса /bestMX dnl необходима поддержка встроенного perl'а). dnl - нестандартный номер порта (отличный от 25 в случае smtp и отличный от dnl 24 в случае lmtp) можно указывать через два символа ":". dnl - можно указывать отдельные маршруты для проверки существования адресов dnl в доменах путем указания суффикса |callout после названия домена. dnl dnl в случае использования транспорта lmtpunix после имени файла UNIX Domain dnl сокета можно через символы ":" указать имя пользователя и группу, от dnl имени которых будет производится запись в файл сокета. dnl dnl domain.tld : local : local_mailbox dnl domain.tld : virt : mailbox@virtual_domain dnl domain.tld : uucp-dom : local_uucp_user dnl domain.tld : smtp : host1::587 : host2 : domain2/MX dnl domain.tld|callout : smtp : domain.tld/bestMX : host1::2025 : host2::2025 dnl domain.tld : lmtp : host1 : host2::2024 dnl domain.tld : lmtpunix : /var/lib/imap/socket/lmtp dnl domain.tld : lmtpunix : /var/lib/imap/socket/lmtp:cyrus:mail dnl dnl запрос к БД MySQL на получение транспорта и маршрута для доставки сообщений dnl define(`confMAILERTABLE_MYSQL', `SELECT transport, route FROM mailertable WHERE domain="${quote_mysql:$domain}"')dnl dnl запрос к БД MySQL на получение транспорта и маршрута для проверки существования почтовых адресов dnl define(`confMAILERTABLE_CALLOUTTABLE_MYSQL', `SELECT transport, route FROM callouttable WHERE domain="${quote_mysql:$domain}"')dnl dnl dnl запрос к БД SQLite на получение транспорта и маршрута для доставки сообщений dnl define(`confMAILERTABLE_SQLITE', `SELECT transport, route FROM mailertable WHERE domain="${quote_sqlite:$domain}"')dnl dnl запрос к БД SQLite на получение транспорта и маршрута для проверки существования почтовых адресов dnl define(`confMAILERTABLE_CALLOUTTABLE_SQLITE', `SELECT transport, route FROM callouttable WHERE domain="${quote_sqlite:$domain}"')dnl dnl ifelse(SECTION, `MAIN', `dnl dnl ifdef(`confPERL',`',` dnl errprint(`*** ERROR: confPERL variable required dnl ')') dnl ifdef(`confPERL',`',`') ifelse(confMAILERTABLE, `TEXT', `dnl LOOKUP_MAILERTABLE_TEXT = \ ${lookup{$local_part@$domain}wildlsearch{CONFDIR/mailertable}{$value}{\ ${lookup{$domain}wildlsearch{CONFDIR/mailertable}}\ }} LOOKUP_CALLOUTTABLE_TEXT = \ ${lookup{$domain|callout}wildlsearch{CONFDIR/mailertable}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl LOOKUP_MAILERTABLE_DBM = \ ${lookup{$local_part@$domain}dbm{CONFDIR/mailertable.db}{$value}{\ ${lookup{$domain}dbm{CONFDIR/mailertable.db}}\ }} LOOKUP_CALLOUTTABLE_DBM = \ ${lookup{$domain}dbm{CONFDIR/mailertable.db}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ') dnl ifelse(SECTION, `MAIN', `') ifelse(SECTION, `ACL_CHECK_RCPT', `dnl # Проверка существования получателей из shared pop доменов deny condition = ${if eq{$acl_m_skip_verify_recipient}{yes}{no}{yes}} ifelse(confMAILERTABLE, `TEXT', `dnl set acl_m0 = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {Address $1, expanded from $local_part$domain, is unrouteable}\ {skip}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl set acl_m0 = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {Address $1, expanded from $local_part$domain, is unrouteable}\ {skip}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl set acl_m0 = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_MYSQL}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {Address $1, expanded from $local_part$domain, is unrouteable}\ {skip}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl set acl_m0 = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {Address $1, expanded from $local_part$domain, is unrouteable}\ {skip}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') condition = ${if eq{$acl_m0}{skip}{no}{yes}} message = $acl_m0 log_message = $acl_m0 ! verify = recipient ')dnl dnl ifelse(SECTION, `ACL_CHECK_RCPT_BOTTOM', `dnl # Прием почты для получателей из shared pop доменов ifelse(confMAILERTABLE, `TEXT', `dnl accept condition = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl accept condition = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl accept condition = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_MYSQL}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl accept condition = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') endpass ') ifelse(SECTION, `ROUTERS', `dnl ifelse_strstr(confDELIVERY_TO, `MDIR_VIRTUAL', `dnl # доставка почты домена в single maildir mailertable_virt: driver = redirect ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {yes}{no}} data = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {yes}{no}} data = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*virt\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match{${extract{transport}{${lookup mysql{confMAILERTABLE_MYSQL}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {yes}{no}} data = ${extract{route}{${lookup mysql{confMAILERTABLE_MYSQL}}}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match{${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}}\ {\N^(?i)\s*virt\s*$\N}\ {yes}{no}} data = ${extract{route}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') # no_verify ') ifelse_strstr(confDELIVERY_TO, `MBOX', `dnl # обработка .forward при доставке почты домена в mailbox mailertable_local_forward: driver = redirect ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {${if exists{/home/$1/.forward}{yes}{no}}}{no}} user = ${if match}\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} file = /home/${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}}\ /.forward ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {${if exists{/home/$1/.forward}{yes}{no}}}{no}} user = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} file = /home/${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}}\ /.forward ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_MYSQL}}}}}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} user = ${extract{route}{${lookup mysql{confMAILERTABLE_MYSQL}}}} require_files = /home/\ ${extract{route}{${lookup mysql{confMAILERTABLE_MYSQL}}}}\ /.forward file = /home/\ ${extract{route}{${lookup mysql{confMAILERTABLE_MYSQL}}}}\ /.forward ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} user = ${extract{route}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}} require_files = /home/\ ${extract{route}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}\ /.forward file = /home/\ ${extract{route}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}\ /.forward ') dnl ifelse(confMAILERTABLE, `SQLITE', `') # no_verify no_expn check_ancestor file_transport = address_file pipe_transport = address_pipe reply_transport = 1 # address_reply ifelse_strstr(confDELIVERY_TO, `FILTERS', `dnl allow_filter ') # доставка почты домена в mailbox mailertable_local: driver = accept transport = mailertable_local_transport ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*\S+$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*\S+$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_MYSQL}}}}}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}}}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') # no_verify ') ifdef(`confMAILERTABLE_LMTP', `ifelse(confMAILERTABLE_LMTP, `NO', `dnl', `dnl # доставка почты по lmtp через UNIX domain socket mailertable_lmtpunix: driver = accept transport = lmtpunix # domains = ! +local_domains ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*lmtpunix\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*lmtpunix\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*lmtpunix\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*lmtpunix\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${if eq{${extract{transport}{${lc:$value}}}}{lmtpunix}{yes}{no}}}{no}} address_data = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${if eq{${extract{transport}{${lc:$value}}}}{lmtpunix}{yes}{no}}}{no}} address_data = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') user = ${extract{2}{:}{$address_data}{$value}{confVIRT_MDIR_USER}} group = ${extract{3}{:}{$address_data}{$value}{confVIRT_MDIR_GROUP}} no_verify # роутинг почты по lmtp mailertable_lmtp: driver = manualroute transport = remote_lmtp # domains = ! +local_domains ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${if eq{${extract{transport}{${lc:$value}}}}{lmtp}{yes}{no}}}{no}} address_data = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${if eq{${extract{transport}{${lc:$value}}}}{lmtp}{yes}{no}}}{no}} address_data = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') ifdef(`confPERL', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N${perl{bestmx}{${lookup dnsdb{mx=$1}}}}\N}\ }}{\N\s\N}{}} ', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N$1\/MX\N}\ }}{\N\s\N}{}} ')dnl ifdef(`confPERL', `') no_verify self = send # использование mailertable для выбора транспорта и маршрута для проверки существования почтовых адресов mailertable_lmtp_callout: driver = manualroute transport = remote_lmtp # domains = ! +local_domains ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_TEXT\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_DBM\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*lmtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_CALLOUTTABLE_MYSQL}}}}}\ {\N^(?i)\s*lmtp\s*$\N}\ {yes}{no}} address_data = ${lookup mysql{confMAILERTABLE_CALLOUTTABLE_MYSQL}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_CALLOUTTABLE_SQLITE}}}}}\ {\N^(?i)\s*lmtp\s*$\N}\ {yes}{no}} address_data = ${lookup sqlite{confSQLITE confMAILERTABLE_CALLOUTTABLE_SQLITE}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') ifdef(`confPERL', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N${perl{bestmx}{${lookup dnsdb{mx=$1}}}}\N}\ }}{\N\s\N}{}} ', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N$1\/MX\N}\ }}{\N\s\N}{}} ')dnl ifdef(`confPERL', `') verify_only self = send ')') dnl ifdef(`confMAILERTABLE_LMTP', `ifelse(confMAILERTABLE_LMTP, `NO', `dnl', `')') # роутинг почты по smtp mailertable_smtp: driver = manualroute transport = remote_smtp ifelse_strstr(confDSN, `SMTP', `dnl dsn_process ') dnl # domains = ! +local_domains ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_TEXT\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_MAILERTABLE_DBM\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${if eq{${extract{transport}{${lc:$value}}}}{smtp}{yes}{no}}}{no}} address_data = ${lookup mysql{confMAILERTABLE_MYSQL}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${if eq{${extract{transport}{${lc:$value}}}}{smtp}{yes}{no}}}{no}} address_data = ${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') ifdef(`confPERL', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N${perl{bestmx}{${lookup dnsdb{mx=$1}}}}\N}\ }}{\N\s\N}{}} ', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N$1\/MX\N}\ }}{\N\s\N}{}} ')dnl ifdef(`confPERL', `') no_verify self = send # использование mailertable для выбора транспорта и маршрута для проверки существования почтовых адресов mailertable_smtp_callout: driver = manualroute transport = remote_smtp # domains = ! +local_domains ifelse(confMAILERTABLE, `TEXT', `dnl condition = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_TEXT\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_TEXT\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl condition = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_DBM\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{yes}{no}} address_data = ${if match{${lc:\ LOOKUP_CALLOUTTABLE_DBM\ }}{\N^(?i)\s*smtp\s*:\s*(\S.+)$\N}{$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match\ {${extract{transport}{${lookup mysql{confMAILERTABLE_CALLOUTTABLE_MYSQL}}}}}\ {\N^(?i)\s*smtp\s*$\N}\ {yes}{no}} address_data = ${lookup mysql{confMAILERTABLE_CALLOUTTABLE_MYSQL}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match\ {${extract{transport}{${lookup sqlite{confSQLITE confMAILERTABLE_CALLOUTTABLE_SQLITE}}}}}\ {\N^(?i)\s*smtp\s*$\N}\ {yes}{no}} address_data = ${lookup sqlite{confSQLITE confMAILERTABLE_CALLOUTTABLE_SQLITE}\ {${extract{route}{${lc:$value}}}}{}} ') dnl ifelse(confMAILERTABLE, `SQLITE', `') ifdef(`confPERL', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N${perl{bestmx}{${lookup dnsdb{mx=$1}}}}\N}\ }}{\N\s\N}{}} ', ` route_data = ${sg{${sg\ {$address_data}\ {\N(?i)([^:\s]+?)\/bestMX\N}\ {\N$1\/MX\N}\ }}{\N\s\N}{}} ')dnl ifdef(`confPERL', `') verify_only ') dnl ifelse(SECTION, `ROUTERS', `') ifelse(SECTION, `TRANSPORTS', `dnl ifdef(`confMAILERTABLE_LMTP', `ifelse(confMAILERTABLE_LMTP, `NO', `dnl', `dnl lmtpunix: driver = lmtp socket = ${extract{1}{:}{$address_data}} transport_filter = /usr/bin/tr -d \\000 # batch_max = 20 ifdef(`confMAIL_BACKUP', `ifelse_strstr(confMAIL_BACKUP, `ROUTER_REDIRECT', ` headers_remove = ${if eq{$local_part@$domain}{confMAIL_BACKUP_ADDR}{}{X-Recipients}} ')') remote_lmtp: driver = smtp protocol = lmtp rcpt_include_affixes = yes transport_filter = /usr/bin/tr -d \\000 port = lmtp ifdef(`confSMTP_AUTH_CLIENT', `ifelse(confSMTP_AUTH_CLIENT, `NO', `dnl', `dnl hosts_try_auth = +hosts_try_auth ')') ifdef(`confSTARTTLS_SKIP_USING', `ifelse(confSTARTTLS_SKIP_USING, `NO', `dnl', `dnl hosts_avoid_tls = +skip_tls_using ')') dnl envelope_to_add return_path_add allow_localhost ifdef(`confMAIL_BACKUP', `ifelse_strstr(confMAIL_BACKUP, `ROUTER_REDIRECT', ` headers_remove = ${if eq{$local_part@$domain}{confMAIL_BACKUP_ADDR}{}{X-Recipients}} ')') ')') dnl ifdef(`confMAILERTABLE_LMTP', `ifelse(confMAILERTABLE_LMTP, `NO', `dnl', `')') ifelse_strstr(confDELIVERY_TO, `MBOX', `dnl # доставка почты домена в mailbox mailertable_local_transport: driver = appendfile delivery_date_add envelope_to_add return_path_add group = mail ifelse(confMAILERTABLE, `TEXT', `dnl user = ${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} file = /var/mail/${if match{\ LOOKUP_MAILERTABLE_TEXT\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} ') dnl ifelse(confMAILERTABLE, `TEXT', `') ifelse(confMAILERTABLE, `DBM', `dnl user = ${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} file = /var/mail/${if match{\ LOOKUP_MAILERTABLE_DBM\ }{\N^(?i)\s*local\s*:\s*(\S+)\s*(:.*)?$\N}\ {$1}{}} ') dnl ifelse(confMAILERTABLE, `DBM', `') ifelse(confMAILERTABLE, `MYSQL', `dnl condition = ${if match\ {${extract{transport}\ {${lookup mysql{confMAILERTABLE_MYSQL}}}\ }}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} user = ${extract{route}\ {${lookup mysql{confMAILERTABLE_MYSQL}}}\ } file = /var/mail/${extract{route}\ {${lookup mysql{confMAILERTABLE_MYSQL}}}\ } ') dnl ifelse(confMAILERTABLE, `MYSQL', `') ifelse(confMAILERTABLE, `SQLITE', `dnl condition = ${if match\ {${extract{transport}\ {${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}\ }}\ {\N^(?i)\s*local\s*$\N}\ {yes}{no}} user = ${extract{route}\ {${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}\ } file = /var/mail/${extract{route}\ {${lookup sqlite{confSQLITE confMAILERTABLE_SQLITE}}}\ } ') dnl ifelse(confMAILERTABLE, `SQLITE', `') mode = 0660 no_mode_fail_narrower ifelse_strstr(confDSN, `LOCAL', `dnl # DSN support for local recipients shadow_transport = DSN_local shadow_condition = ${if and{\ {!eq{${extract{Return_Receipt_To}{$acl_m19}}}{}}\ {match{${extract{rcpt}{$acl_m19}}}{, ${original_local_part}@${original_domain},}}\ }{yes}{no}} ') dnl ifdef(`confMAIL_BACKUP', `ifelse_strstr(confMAIL_BACKUP, `ROUTER_REDIRECT', ` headers_remove = ${if eq{$local_part@$domain}{confMAIL_BACKUP_ADDR}{}{X-Recipients}} ')') ') dnl ifelse_strstr(confDELIVERY_TO, `MBOX', `') ') dnl ifelse(SECTION, `TRANSPORTS', `')