{"id":2290,"date":"2017-08-30T17:10:55","date_gmt":"2017-08-30T17:10:55","guid":{"rendered":"https:\/\/tst-amo.pp.ua\/blog\/?p=2290"},"modified":"2017-11-02T12:05:23","modified_gmt":"2017-11-02T12:05:23","slug":"postfix-dovecot-mysql-postfix-admin-%d1%87%d0%b0%d1%81%d1%82%d1%8c-1-%d1%83%d1%81%d1%82%d0%b0%d0%bd%d0%be%d0%b2%d0%ba%d0%b0-%d0%b8-%d0%bd%d0%b0%d1%81%d1%82%d1%80%d0%be%d0%b9%d0%ba-2","status":"publish","type":"post","link":"https:\/\/tst-amo.net.ua\/blog\/?p=2290","title":{"rendered":"Postfix + Dovecot + MySQL + Postfix Admin, \u0447\u0430\u0441\u0442\u044c 3 \u2013 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0438 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 Dovecot"},"content":{"rendered":"<p>\u041e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438\u00a0<strong>Dovecot<\/strong>\u00a0\u2013\u00a0\/usr\/local\/etc\/dovecot\/dovecot.conf:<span id=\"more-1119\"><\/span><\/p>\n<pre>cat\u00a0 \/usr\/local\/etc\/dovecot\/dovecot.conf | grep -v '^#' | sed '\/^$\/d' | more\r\n\r\n# \u041f\u043e\u0441\u043b\u0435 \u043e\u0442\u043b\u0430\u0434\u043a\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0434\u0435\u0431\u0430\u0433\u0438!!!\r\nauth_debug = yes\r\nauth_debug_passwords = yes\r\nauth_mechanisms = plain login cram-md5\r\nauth_socket_path = \/var\/run\/dovecot\/auth-userdb\r\nauth_verbose = yes\r\nauth_verbose_passwords = yes\r\nbase_dir = \/var\/run\/dovecot\/\r\n\r\ndisable_plaintext_auth = no\r\n\r\nlisten = *\r\nlog_path = \/var\/log\/dovecot.log\r\nlogin_log_format_elements = user=&lt;%u&gt; method=%m rip=%r lip=%l mpid=%e %c\r\n\r\nlogin_trusted_networks = 127.0.0.0\/8, 192.168.1.0\/24\r\n\r\nmail_debug = yes\r\n\r\nmail_location = maildir:~\/Maildir\r\n\r\nprotocols = imap pop3\r\n\r\nnamespace inbox {\r\n inbox = yes\r\n # list = yes\r\n location =\r\n mailbox Drafts {\r\n special_use = \\Drafts\r\n }\r\n mailbox Junk {\r\n special_use = \\Junk\r\n }\r\n mailbox Sent {\r\n special_use = \\Sent\r\n }\r\n mailbox \"Sent Messages\" {\r\n special_use = \\Sent\r\n }\r\n mailbox Trash {\r\n special_use = \\Trash\r\n }\r\n prefix =\r\n separator = \/\r\n subscriptions = yes\r\n type = private\r\n}\r\n\r\npassdb {\r\n args = \/usr\/local\/etc\/dovecot\/dovecot-sql.conf.ext\r\n driver = sql\r\n}\r\nuserdb {\r\n args = \/usr\/local\/etc\/dovecot\/dovecot-sql.conf.ext\r\n driver = sql\r\n}\r\n\r\n####\r\nservice auth {\r\n unix_listener auth-userdb {\r\n group = postfix\r\n mode = 0666\r\n user = postfix\r\n }\r\n user = dovecot\r\n}\r\nservice imap-login {\r\n inet_listener imap {\r\n port = 143\r\n }\r\n}\r\nservice imap {\r\n process_limit = 1024\r\n}\r\nservice pop3-login {\r\n inet_listener pop3 {\r\n port = 110\r\n }\r\n}\r\nservice pop3 {\r\n process_limit = 1024\r\n}\r\nssl = no\r\n\r\nuserdb {\r\n driver = passwd\r\n}\r\n\r\nverbose_proctitle = yes\r\nverbose_ssl = yes\r\nprotocol lmtp {\r\n mail_plugins =\r\n}\r\nprotocol imap {\r\n mail_max_userip_connections = 10\r\n mail_plugins =\r\n}\r\nprotocol pop3 {\r\n mail_max_userip_connections = 10\r\n mail_plugins =\r\n}<\/pre>\n<div id=\"highlighter_259506\" class=\"syntaxhighlighter \">\n<div class=\"lines\">\n<div class=\"line alt1\">\u0420\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438 \u0440\u0430\u0431\u043e\u0442\u044b \u0441\u00a0<strong>MySQL<\/strong>\u00a0\u2013\u00a0<em>\/usr\/local\/etc\/dovecot\/dovecot-sql.conf.ext<\/em>.\u00a0<strong>\u0412\u0410\u0416\u041d\u041e<\/strong>: \u043f\u0430\u0440\u0430\u043c\u0435\u0442\u0440\u00a0<em>query<\/em>\u00a0\u043c\u043e\u0436\u0435\u0442 \u043c\u0435\u043d\u044f\u0442\u044c\u0441\u044f \u0432 \u0437\u0430\u0432\u0438\u0441\u0438\u043c\u043e\u0441\u0442\u0438 \u043e\u0442 \u0432\u0435\u0440\u0441\u0438\u0438 \u0441\u0435\u0440\u0432\u0435\u0440\u0430, \u0432 \u043e\u043f\u0438\u0441\u044b\u0432\u0430\u0435\u043c\u043e\u043c \u043f\u0440\u0438\u043c\u0435\u0440\u0435 \u0438\u0441\u043f\u043e\u043b\u044c\u0437\u0443\u0435\u0442\u0441\u044f dovecot2:<\/div>\n<\/div>\n<\/div>\n<pre class=\"line alt1\"># cat \/usr\/local\/etc\/dovecot\/dovecot-sql.conf.ext | grep -v '^#' | sed '\/^$\/d' | more\r\n# Database driver: mysql, pgsql, sqlite\r\ndriver = mysql\r\nconnect = host=localhost dbname=postfix user=postfix password=mypassword\r\n\r\ndefault_pass_scheme = MD5-CRYPT\r\n\r\n# \u0417\u0430\u043f\u0440\u043e\u0441, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0439 \u043f\u0430\u0440\u043e\u043b\u044c\r\npassword_query = SELECT `username` as `user`, `password` FROM `mailbox` WHERE `username` = '%n@%d' AND `active`='1'\r\n\r\n# \u0417\u0430\u043f\u0440\u043e\u0441, \u0432\u043e\u0437\u0432\u0440\u0430\u0449\u0430\u044e\u0449\u0438\u0439 \u0438\u043d\u0444\u0443 \u043e \u044e\u0437\u0435\u0440\u0435 \u0438 \u043f\u0440\u043e\u0432\u0435\u0440\u044f\u044e\u0449\u0438\u0439 \u043a\u0432\u043e\u0442\u0443\r\nuser_query = SELECT CONCAT('\/var\/vmail\/', `maildir`) AS \\\r\n `home`, 65534 AS `uid`, 65534 AS `gid`, concat('dict:storage=', \\\r\n CAST(ROUND(quota \/ 1024) AS CHAR), '::proxy::sqlquota') \\\r\n AS quota, CONCAT('*:storage=', CAST(quota AS CHAR), 'B') AS quota_rule \\\r\n FROM `mailbox` WHERE `username` = '%n@%d' AND `active`='1'\r\n\r\n# Query to get a list of all usernames.\r\niterate_query = SELECT username AS user FROM mailbox<\/pre>\n<div id=\"highlighter_936806\" class=\"syntaxhighlighter \">\n<div class=\"lines\">\n<div class=\"line alt1\">\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c \u043f\u043e\u043b\u044c\u0437\u043e\u0432\u0430\u0442\u0435\u043b\u044f <em>dovecot<\/em> \u0432 \u0433\u0440\u0443\u043f\u043f\u0443 <em>mail<\/em><\/div>\n<pre class=\"line alt1\">cat \/etc\/group | grep mail\r\nmail:*:6:postfix,dovecot<\/pre>\n<div class=\"line alt1\">\u0414\u0430\u043b\u0435\u0435<\/div>\n<pre class=\"line alt1\">chown dovecot:mail \/var\/log\/dovecot.log\r\nchmod 0666 \/var\/log\/dovecot.log<\/pre>\n<div class=\"line alt1\">\u041f\u0440\u043e\u0434\u043e\u043b\u0436\u0430\u0435\u043c<\/div>\n<div class=\"line alt1\">\n<pre class=\"line alt1\">chown -R nobody:nobody \/var\/vmail\r\nchmod -R 0777 \/var\/vmail<\/pre>\n<\/div>\n<div class=\"line alt1\">\u041f\u0435\u0440\u0435\u0437\u0430\u043f\u0443\u0441\u043a\u0430\u0435\u043c\u00a0<strong>Dovecot<\/strong>:<\/div>\n<\/div>\n<\/div>\n<pre># service dovecot onerestart<\/pre>\n<p>\u041f\u0440\u043e\u0432\u0435\u0440\u044f\u0435\u043c<\/p>\n<pre>root@tmail:\/var\/log # telnet localhost 110\r\nTrying 127.0.0.1...\r\nConnected to localhost.\r\nEscape character is '^]'.\r\n+OK [XCLIENT] Dovecot ready.\r\nuser acc@domain.ltd\r\n+OK\r\npass q1w2e3\r\n+OK Logged in.\r\nlist\r\n+OK 2 messages:\r\n1 348\r\n2 348\r\n.\r\nquit\r\n+OK Logging out.\r\nConnection closed by foreign host.<\/pre>\n<p>\u0414\u043e\u0431\u0430\u0432\u043b\u044f\u0435\u043c\u00a0<strong>Dovecot<\/strong>\u00a0\u0432 \u0437\u0430\u043f\u0443\u0441\u043a \u043f\u0440\u0438 \u0437\u0430\u0433\u0440\u0443\u0437\u043a\u0435 \u0441\u0438\u0441\u0442\u0435\u043c\u044b \u0432 \u0444\u0430\u0439\u043b\u00a0<em>\/etc\/rc.conf<\/em>:<\/p>\n<pre>dovecot_enable=\"YES\"<\/pre>\n<div id=\"highlighter_103005\" class=\"syntaxhighlighter \">\n<div class=\"lines\">\n<div class=\"line alt1\">\u041d\u0430 \u044d\u0442\u043e\u043c \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 \u043f\u043e\u0447\u0442\u043e\u0432\u043e\u0433\u043e \u0441\u0435\u0440\u0432\u0435\u0440\u0430 \u0437\u0430\u0432\u0435\u0440\u0448\u0435\u043d\u0430.<\/div>\n<\/div>\n<\/div>\n<p>\u041f\u0440\u0438 \u043f\u0440\u043e\u0431\u043b\u0435\u043c\u0430\u0445 \u2013 \u043d\u0435 \u0437\u0430\u0431\u044b\u0432\u0430\u0435\u043c \u0432 \u043f\u0435\u0440\u0432\u0443\u044e \u043e\u0447\u0435\u0440\u0435\u0434\u044c \u0441\u043c\u043e\u0442\u0440\u0435\u0442\u044c \u043b\u043e\u0433\u00a0<em>\/var\/log\/maillog.<\/em><\/p>\n<p>\u041f\u043e\u0441\u043b\u0435 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0438 postfix \u043d\u0443\u0436\u043d\u043e \u043f\u0435\u0440\u0435\u0441\u0442\u0440\u043e\u0438\u0442\u044c \u0431\u0430\u0437\u0443 \u0434\u0430\u043d\u043d\u044b\u0445 \u0434\u043b\u044f \u0444\u0430\u0439\u043b\u0430 \u043f\u043e\u0447\u0442\u043e\u0432\u044b\u0445 \u0430\u043b\u0438\u0430\u0441\u043e\u0432 \/etc\/aliases \u0438 \/etc\/aliases.db \u043a\u043e\u043c\u0430\u043d\u0434\u043e\u0439 <em>newaliases<\/em> \u0438\u043d\u0430\u0447\u0435 \u043f\u043e\u0447\u0442\u0430 \u043c\u043e\u0436\u0435\u0442 \u043d\u0435 \u0445\u043e\u0434\u0438\u0442\u044c.<\/p>\n<p>&nbsp;<\/p>\n<p><a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2210\">\u0427\u0430\u0441\u0442\u044c 1 (PostfixAdmin)<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2214\">\u0427\u0430\u0441\u0442\u044c 2 (Postfix)<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=23\">Apache24, MySQL56, PhP5<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2384\">Apache24 + SSL \u0438 redirect http to https<br \/>\n<\/a><a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2341\">Clamav<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2336\">Spamassassin<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2344\">Amavis-new<\/a>\u00a0+ \u0441\u0432\u044f\u0437\u044c \u0441 Postfix<br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2409\">SSL \u0441\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442 \u0434\u043b\u044f Postfix<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2419\">SSL \u0441\u0435\u0440\u0442\u0438\u0444\u0438\u043a\u0430\u0442 \u0434\u043b\u044f Dovecot<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2429\">Sieve + Dovecot<\/a><br \/>\n<a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2448\">OpenDKIM + Postfix<\/a><\/p>\n<p><a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2419\">\u00a0<\/a><\/p>\n<p><a href=\"https:\/\/tst-amo.pp.ua\/blog\/?p=2409\">\u00a0<\/a><\/p>\n<div class=\"pdfprnt-buttons pdfprnt-buttons-post pdfprnt-bottom-right\"><a href=\"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=wpv2posts2290&print=pdf\" class=\"pdfprnt-button pdfprnt-button-pdf\" target=\"_blank\"><img decoding=\"async\" src=\"https:\/\/tst-amo.net.ua\/blog\/wp-content\/plugins\/pdf-print\/images\/pdf.png\" alt=\"image_pdf\" title=\"View PDF\" \/><\/a><a href=\"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=wpv2posts2290&print=print\" class=\"pdfprnt-button pdfprnt-button-print\" target=\"_blank\"><img decoding=\"async\" src=\"https:\/\/tst-amo.net.ua\/blog\/wp-content\/plugins\/pdf-print\/images\/print.png\" alt=\"image_print\" title=\"Print Content\" \/><\/a><\/div>","protected":false},"excerpt":{"rendered":"<p>\u041e\u0442\u0440\u0435\u0434\u0430\u043a\u0442\u0438\u0440\u0443\u0435\u043c \u0444\u0430\u0439\u043b \u043a\u043e\u043d\u0444\u0438\u0433\u0443\u0440\u0430\u0446\u0438\u0438\u00a0Dovecot\u00a0\u2013\u00a0\/usr\/local\/etc\/dovecot\/dovecot.conf: cat\u00a0 \/usr\/local\/etc\/dovecot\/dovecot.conf | grep -v &#8216;^#&#8217; | sed &#8216;\/^$\/d&#8217; | more # \u041f\u043e\u0441\u043b\u0435 \u043e\u0442\u043b\u0430\u0434\u043a\u0438 \u043e\u0442\u043a\u043b\u044e\u0447\u0438\u0442\u044c \u0434\u0435\u0431\u0430\u0433\u0438!!! auth_debug = yes auth_debug_passwords = yes auth_mechanisms = plain login cram-md5 auth_socket_path = \/var\/run\/dovecot\/auth-userdb auth_verbose = yes auth_verbose_passwords = yes base_dir = \/var\/run\/dovecot\/ disable_plaintext_auth = no listen = * log_path = \/var\/log\/dovecot.log login_log_format_elements = user=&lt;%u&gt; method=%m &#8230;<\/p>\n<p><a href=\"https:\/\/tst-amo.net.ua\/blog\/?p=2290\" class=\"more-link\">Continue reading &lsquo;Postfix + Dovecot + MySQL + Postfix Admin, \u0447\u0430\u0441\u0442\u044c 3 \u2013 \u0443\u0441\u0442\u0430\u043d\u043e\u0432\u043a\u0430 \u0438 \u043d\u0430\u0441\u0442\u0440\u043e\u0439\u043a\u0430 Dovecot&rsquo; &raquo;<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[12,50,7],"tags":[],"class_list":["post-2290","post","type-post","status-publish","format-standard","hentry","category-dovecot","category-freebsd","category-mail"],"_links":{"self":[{"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/posts\/2290"}],"collection":[{"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2290"}],"version-history":[{"count":21,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/posts\/2290\/revisions"}],"predecessor-version":[{"id":2529,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=\/wp\/v2\/posts\/2290\/revisions\/2529"}],"wp:attachment":[{"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2290"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=2290"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/tst-amo.net.ua\/blog\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=2290"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}