Created
February 1, 2019 10:05
-
-
Save ketankr9/8ac07ab222c27205eca1988a9a816de7 to your computer and use it in GitHub Desktop.
mailserver postfix configuration and dovecot imap/pop3 setup
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#$$$ cat /etc/dovecot/dovecot.conf | |
## Dovecot configuration file | |
# If you're in a hurry, see http://wiki2.dovecot.org/QuickConfiguration | |
# "doveconf -n" command gives a clean output of the changed settings. Use it | |
# instead of copy&pasting files when posting to the Dovecot mailing list. | |
# '#' character and everything after it is treated as comments. Extra spaces | |
# and tabs are ignored. If you want to use either of these explicitly, put the | |
# value inside quotes, eg.: key = "# char and trailing whitespace " | |
# Most (but not all) settings can be overridden by different protocols and/or | |
# source/destination IPs by placing the settings inside sections, for example: | |
# protocol imap { }, local 127.0.0.1 { }, remote 10.0.0.0/8 { } | |
protocols = imap pop3 | |
# Default values are shown for each setting, it's not required to uncomment | |
# those. These are exceptions to this though: No sections (e.g. namespace {}) | |
# or plugin settings are added by default, they're listed only as examples. | |
# Paths are also just examples with the real defaults being based on configure | |
# options. The paths listed here are for configure --prefix=/usr | |
# --sysconfdir=/etc --localstatedir=/var | |
# Enable installed protocols | |
!include_try /usr/share/dovecot/protocols.d/*.protocol | |
# A comma separated list of IPs or hosts where to listen in for connections. | |
# "*" listens in all IPv4 interfaces, "::" listens in all IPv6 interfaces. | |
# If you want to specify non-default ports or anything more complex, | |
# edit conf.d/master.conf. | |
listen = *, :: | |
# Base directory where to store runtime data. | |
#base_dir = /var/run/dovecot/ | |
# Name of this instance. In multi-instance setup doveadm and other commands | |
# can use -i <instance_name> to select which instance is used (an alternative | |
# to -c <config_path>). The instance name is also added to Dovecot processes | |
# in ps output. | |
#instance_name = dovecot | |
# Greeting message for clients. | |
#login_greeting = Dovecot ready. | |
# Space separated list of trusted network ranges. Connections from these | |
# IPs are allowed to override their IP addresses and ports (for logging and | |
# for authentication checks). disable_plaintext_auth is also ignored for | |
# these networks. Typically you'd specify your IMAP proxy servers here. | |
#login_trusted_networks = | |
# Space separated list of login access check sockets (e.g. tcpwrap) | |
#login_access_sockets = | |
# With proxy_maybe=yes if proxy destination matches any of these IPs, don't do | |
# proxying. This isn't necessary normally, but may be useful if the destination | |
# IP is e.g. a load balancer's IP. | |
#auth_proxy_self = | |
# Show more verbose process titles (in ps). Currently shows user name and | |
# IP address. Useful for seeing who are actually using the IMAP processes | |
# (eg. shared mailboxes or if same uid is used for multiple accounts). | |
#verbose_proctitle = no | |
# Should all processes be killed when Dovecot master process shuts down. | |
# Setting this to "no" means that Dovecot can be upgraded without | |
# forcing existing client connections to close (although that could also be | |
# a problem if the upgrade is e.g. because of a security fix). | |
#shutdown_clients = yes | |
# If non-zero, run mail commands via this many connections to doveadm server, | |
# instead of running them directly in the same process. | |
#doveadm_worker_count = 0 | |
# UNIX socket or host:port used for connecting to doveadm server | |
#doveadm_socket_path = doveadm-server | |
# Space separated list of environment variables that are preserved on Dovecot | |
# startup and passed down to all of its child processes. You can also give | |
# key=value pairs to always set specific settings. | |
#import_environment = TZ | |
## | |
## Dictionary server settings | |
## | |
# Dictionary can be used to store key=value lists. This is used by several | |
# plugins. The dictionary can be accessed either directly or though a | |
# dictionary server. The following dict block maps dictionary names to URIs | |
# when the server is used. These can then be referenced using URIs in format | |
# "proxy::<name>". | |
dict { | |
#quota = mysql:/etc/dovecot/dovecot-dict-sql.conf.ext | |
#expire = sqlite:/etc/dovecot/dovecot-dict-sql.conf.ext | |
} | |
# Most of the actual configuration gets included below. The filenames are | |
# first sorted by their ASCII value and parsed in that order. The 00-prefixes | |
# in filenames are intended to make it easier to understand the ordering. | |
!include conf.d/*.conf | |
# A config file can also tried to be included without giving an error if | |
# it's not found: | |
!include_try local.conf | |
disable_plaintext_auth = no | |
mail_privileged_group = mail | |
mail_location = mbox:/var/spool/mail/:INBOX=/var/mail/%u | |
userdb { | |
driver = passwd | |
} | |
passdb { | |
args = %s | |
driver = pam | |
} | |
protocols = " imap" | |
protocol imap { | |
mail_plugins = " autocreate" | |
} | |
plugin { | |
autocreate = Trash | |
autocreate2 = Sent | |
autosubscribe = Trash | |
autosubscribe2 = Sent | |
} | |
service auth { | |
unix_listener /var/spool/postfix/private/auth { | |
group = postfix | |
mode = 0660 | |
user = postfix | |
} | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
#$$$ cat /etc/postfix/main.cf | |
# See /usr/share/postfix/main.cf.dist for a commented, more complete version | |
# Debian specific: Specifying a file name will cause the first | |
# line of that file to be used as the name. The Debian default | |
# is /etc/mailname. | |
smtpd_banner = $myhostname ESMTP $mail_name (Ubuntu) | |
biff = no | |
# appending .domain is the MUA's job. | |
append_dot_mydomain = no | |
# Uncomment the next line to generate "delayed mail" warnings | |
#delay_warning_time = 4h | |
readme_directory = no | |
# TLS parameters | |
smtpd_tls_cert_file=/etc/ssl/certs/ssl-cert-snakeoil.pem | |
smtpd_tls_key_file=/etc/ssl/private/ssl-cert-snakeoil.key | |
smtpd_use_tls=yes | |
smtpd_tls_session_cache_database = btree:${data_directory}/smtpd_scache | |
smtp_tls_session_cache_database = btree:${data_directory}/smtp_scache | |
# See /usr/share/doc/postfix/TLS_README.gz in the postfix-doc package for | |
# information on enabling SSL in the smtp client. | |
smtpd_relay_restrictions = permit_mynetworks permit_sasl_authenticated defer_unauth_destination | |
myhostname = mail.mybuntu.com | |
mydomain = mybuntu.com | |
myorigin = $mydomain | |
alias_maps = hash:/etc/aliases | |
alias_database = hash:/etc/aliases | |
#mydestination = $myhostname, mybuntu, localhost.localdomain, localhost | |
mydestination = $myhostname, mybuntu, localhost.localdomain, localhost, $mydomain, mail.$mydomain, www.$mydomain | |
mail_spool_directory = /var/spool/mail | |
relayhost = | |
mynetworks = 172.17.0.0/18, 127.0.0.0/8 [::ffff:127.0.0.0]/104 [::1]/128 | |
# force /etc/hosts DNS lookup | |
lmtp_host_lookup = native | |
smtp_host_lookup=native | |
#disable_dns_lookups = yes | |
ignore_mx_lookup_error = yes | |
mailbox_size_limit = 0 | |
#home_mailbox = Maildir/ | |
recipient_delimiter = + | |
#inet_interfaces = loopback-only | |
inet_interfaces = all | |
default_transport = error | |
relay_transport = error | |
inet_protocols = all |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment