Attention
Check out the lightweight on-premises email archiving software developed by iRedMail team: Spider Email Archiver.
Remote Upgrade Assistance
Check out our remote upgrade support if you need assistance.
vmail
database.postfix-pregreet
.maddr.email_raw
to store mail address without address extension.b.barracudacentral.org
/etc/iredmail-release
with new iRedMail version numberiRedMail stores the release version in /etc/iredmail-release
after
installation, it's recommended to update this file after you upgraded iRedMail,
so that you can know which version of iRedMail you're running. For example:
0.9.8
Please follow below tutorial to upgrade iRedAPD to the latest stable release: Upgrade iRedAPD to the latest stable release
Please follow this tutorial to upgrade iRedAdmin open source edition to the latest stable release: Upgrade iRedAdmin to the latest stable release
Roundcube 1.3
With the release of Roundcube 1.3.0, the previous stable release branches 1.2.x and 1.1.x will switch in to LTS low maintenance mode which means they will only receive important security updates but no longer any regular improvement updates.
Please follow Roundcube official tutorial to upgrade Roundcube webmail to the latest stable release immediately:
SOGo v4 was released on Mar 7, 2018 by the SOGo team (https://sogo.nu), it will become the main branch with most active development.
If you're satisfied with SOGo v3, you're free to continue running v3. but if you want to try v4, please follow our tutorial below to upgrade it.
Attention
This is only applicable to FreeBSD.
Currently only FreeBSD offers Dovecot 2.3 by the ports tree, other Linux/BSD distributions still offers Dovecot 2.2, you should stick to Dovecot 2.2 if your Linux/BSD vendor doesn't offer 2.3 yet.
Please follow our tutorial below to upgrade Dovecot:
SOGo backup script /var/vmail/backup/backup_sogo.sh
shipped in iRedMail-0.9.7
and earlier releases contains 3 issues:
sogo-tool
on FreeBSD. This issue causes our script
didn't backup any sogo data on FreeBSD at all.To fix them, please download the latest version and override the one on your system:
Attention
Script backup_sogo.sh
uses /var/vmail/backup
to store backup files by
default, if you use a different directory, please edit this file and modify
parameter BACKUP_ROOTDIR=
to use the correct one.
cd /var/vmail/backup/
rm -f backup_sogo.sh
wget https://github.com/iredmail/iRedMail/raw/1.0/tools/backup_sogo.sh
chown root backup_sogo.sh
chmod 0400 backup_sogo.sh
postfix-pregreet
Attention
This is not applicable to OpenBSD because we don't have Fail2ban running on OpenBSD.
Quote from Postfix website:
The SMTP protocol is a classic example of a protocol where the server speaks before the client. postscreen(8) detects zombies that are in a hurry and that speak before their turn.
Many spammers are in a hurry to transfer message to your server, we'd like to block them due to not follow RFC.
During mail server maintenance, we found many spammers from China mainland
cannot pass this pregreet test and all of them use ylmf-pc
as HELO hostname.
it's very possible that they're running an illegal Windows XP system which were
installed with a malware Windows XP ISO image.
Steps to create this new Fail2ban jail:
cd /etc/fail2ban/filter.d/
wget https://github.com/iredmail/iRedMail/raw/1.0/samples/fail2ban/filter.d/postfix-pregreet.iredmail.conf
Create new file /etc/fail2ban/jail.d/postfix-pregreet.local
with content
below:
Attention
Please make sure you're using correct Postfix log file in logpath =
parameter. On RHEL/CentOS/FreeBSD, it's /var/log/maillog
. On
Debian/Ubuntu, it's /var/log/mail.log
.
[postfix-pregreet]
enabled = true
filter = postfix-pregreet.iredmail
logpath = /var/log/maillog
maxretry = 1
action = iptables-multiport[name=postfix-pregreet, port="25", protocol=tcp]
Attention
This is only applicable to Nginx.
With default iRedMail settings, Nginx snippet file /etc/nginx/templates/iredadmin.tmpl
(on Linux/OpenBSD) or /usr/local/etc/nginx/templates/iredadmin.tmpl
(on FreeBSD)
hard-codes static file types like below:
location ~ ^/iredadmin/static/(.*)\.(png|jpg|gif|css|js) {
alias /var/www/iredadmin/static/$1.$2;
}
Note: The path in alias
directive is different on different Linux/BSD distributions.
Please replace it by:
location ~ ^/iredadmin/static/(.*) {
alias /var/www/iredadmin/static/$1;
}
Reloading or restarting Nginx service is required.
iRedMail integrates mlmmj as mailing list manager (integration tutorial
mentioned later in this tutorial), it supports subscription and unsubscription
from web page. To hide the application handle the subscription/unsubscription
behind it, iRedMail requires a new URL https://<server>/newsletter/
for this
purpose.
Please append lines below to file /etc/nginx/templates/iredadmin.tmpl
(on Linux/OpenBSD) or /usr/local/etc/nginx/templates/iredadmin.tmpl
(on
FreeBSD)
# Handle newsletter-style subscription/unsubscription supported in iRedAdmin-Pro.
location ~ ^/newsletter/ {
rewrite /newsletter/(.*) /iredadmin/newsletter/$1 last;
}
Reloading or restarting Nginx service is required.
Attention
This is only applicable to Nginx.
With default iRedMail settings, Nginx doesn't block access to Roundcube
sensitive files and .htaccess
file, this may leak users' PGP keys.
Please follow steps below to fix it.
Please open file /etc/nginx/templates/roundcube.tmpl
(Linux/OpenBSD) or
/usr/local/etc/nginx/templates/roundcube.tmpl
(FreeBSD), add lines below
ABOVE any existing lines:
# Block access to default directories and files under these directories
location ~ ^/mail/(bin|config|installer|logs|SQL|temp|vendor)($|/.*) { deny all; }
# Block access to default files under top-directory and files start with same name.
location ~ ^/mail/(CHANGELOG|composer.json|INSTALL|jsdeps.json|LICENSE|README|UPGRADING)($|.*) { deny all; }
# Block plugin config files and sample config files.
location ~ ^/mail/plugins/.*/config.inc.php.* { deny all; }
# Block access to plugin data
location ~ ^/mail/plugins/enigma/home($|/.*) { deny all; }
Please open file /etc/nginx/templates/roundcube-subdomain.tmpl
(Linux/OpenBSD) or /usr/local/etc/nginx/templates/roundcube-subdomain.tmpl
(FreeBSD), add lines below ABOVE any existing lines:
# Block access to default directories and files under these directories
location ~ ^/(bin|config|installer|logs|SQL|temp|vendor)($|/.*) { deny all; }
# Block access to default files under top-directory and files start with same name.
location ~ ^/(CHANGELOG|composer.json|INSTALL|jsdeps.json|LICENSE|README|UPGRADING)($|.*) { deny all; }
# Block plugin config files and sample config files.
location ~ ^/plugins/.*/config.inc.php.* { deny all; }
# Block access to plugin data
location ~ ^/plugins/enigma/home($|/.*) { deny all; }
Open file /etc/nginx/sites-available/00-default.conf
AND 00-default-ssl.conf
,
make sure template file misc.tmpl
is loaded before other template files.
For example, your existing config file may look like this:
server {
...
include /etc/nginx/templates/...;
include /etc/nginx/templates/...;
include /etc/nginx/templates/misc.tmpl;
}
Please move the misc.tmpl
line ABOVE any other include
directive.
Final setting should look like this:
server {
...
include /etc/nginx/templates/misc.tmpl;
include /etc/nginx/templates/...;
include /etc/nginx/templates/...;
}
Note: Nginx in iRedMail-0.9.7 loads modular config files from
/etc/nginx/sites-conf.d/default/
and /etc/nginx/sites-conf.d/default-ssl/
instead of storing all configurations for default web hosts in one file, in
this case you need to:
/etc/nginx/sites-conf.d/default/99-include-tmpl-misc.conf
to
/etc/nginx/sites-conf.d/default/1-include-tmpl-misc.conf
./etc/nginx/sites-conf.d/default-ssl/99-include-tmpl-misc.conf
to
/etc/nginx/sites-conf.d/default-ssl/1-include-tmpl-misc.conf
.Restarting Nginx service is required.
b.barracudacentral.org
Postfix config file (/etc/postfix/main.cf
on Linux/OpenBSD, or
/usr/local/etc/postfix/main.cf
on FreeBSD) generated by iRedMail enables
DNSBL service for postscreen service like below:
postscreen_dnsbl_sites =
zen.spamhaus.org=127.0.0.[2..11]*3
b.barracudacentral.org=127.0.0.[2..11]*2
but site b.barracudacentral.org
returns only domain 127.0.0.2
(instead of
a range from 127.0.0.2
to 127.0.0.11
), so we should change the
b.barracudacentral.org=127.0.0.[2..11]*2
line to:
postscreen_dnsbl_sites =
zen.spamhaus.org=127.0.0.[2..11]*3
b.barracudacentral.org=127.0.0.2*2
Reloading or restarting Postfix is required.
uwsgi is the interface between Nginx and iRedAdmin, so if you're running iRedAdmin, it's recommended to upgrade uwsgi to the latest version, 2.0.17.
Steps: Download the latest uwsgi, compile it, then restart uwsgi service.
cd /root/
ftp https://projects.unbit.it/downloads/uwsgi-2.0.17.tar.gz
tar zxf uwsgi-2.0.17.tar.gz
cd uwsgi-2.0.17
python setup.py install
uwsgi should be succesfully installed, then restart uwsgi service:
rcctl restart uwsgi
If you may need to get more info of (locally) delivered mail messages,
Dovecot setting deliver_log_format
can log extra mail subject, sender, and
message size in mail deliver log. Please append this setting in Dovecot config
file dovecot.conf
, then restart or reload Dovecot service.
* On Linux/OpenBSD, it's /etc/dovecot/dovecot.conf
* On FreeBSD, it's /usr/local/etc/dovecot/dovecot.conf
deliver_log_format = from=%{from}, envelope_sender=%{from_envelope}, subject=%{subject}, msgid=%m, size=%{size}, %$
iRedMail-0.9.8 integrates netdata as an optional component, it's a fancy system monitor to help you understand how your iRedMail server runs.
To integrate netdata, please follow our tutorial below:
Unfortunately, netdata doesn't work on OpenBSD.
Please open OpenLDAP config file slapd.conf
:
/etc/openldap/slapd.conf
/etc/ldap/slapd.conf
/usr/local/etc/openldap/slapd.conf
/etc/openldap/slapd.conf
.ldapd(8)
as LDAP server, no need to fix ACL
issue (access to dn.subtree=
), but still need to index new
attributes.find lines below:
access to dn.subtree="o=domains,dc=xxx,dc=xxx"
by anonymous auth
by self write
by dn.exact="cn=vmail,dc=xxx,dc=xxx" read
by dn.exact="cn=vmailadmin,dc=xxx,dc=xxx" write
by users none
Replace the last line by users none
by:
by users read
slapd.conf
:index member,uniqueMember eq,pres
index mailingListID eq
Attention
For OpenBSD ldapd(8)
server, please add lines below inside the
namespace xxx {}
block:
index member index uniqueMember index mailingListID
iRedMail-0.9.8 introduces 1 new LDAP attribute for mailing list account:
mailingListID
: used to store a server-wide unique id, currently is used
for mailing list subscription/unsubscription (a.k.a. newsletter).Download the latest iRedMail LDAP schema file
cd /tmp
wget https://github.com/iredmail/iRedMail/raw/1.0/samples/iredmail/iredmail.schema
cd /etc/openldap/schema/
cp iredmail.schema iredmail.schema.bak
cp -f /tmp/iredmail.schema /etc/openldap/schema/
cd /tmp
wget https://github.com/iredmail/iRedMail/raw/1.0/samples/iredmail/iredmail.schema
cd /etc/ldap/schema/
cp iredmail.schema iredmail.schema.bak
cp -f /tmp/iredmail.schema /etc/ldap/schema/
cd /tmp
wget https://github.com/iredmail/iRedMail/raw/1.0/samples/iredmail/iredmail.schema
cd /usr/local/etc/openldap/schema/
cp iredmail.schema iredmail.schema.bak
cp -f /tmp/iredmail.schema /usr/local/etc/openldap/schema/
On OpenBSD:
Note: if you're running ldapd as LDAP server, the schema directory is
/etc/ldap
, and service name isldapd
.
cd /tmp
ftp https://github.com/iredmail/iRedMail/raw/1.0/samples/iredmail/iredmail.schema
cd /etc/openldap/schema/
cp iredmail.schema iredmail.schema.bak
cp -f /tmp/iredmail.schema /etc/openldap/schema/
Dovecot-2.3 has an internal change which impacts mail accounts created by iRedMail, it requires 2 new ldap attribute/value pairs for all mail users:
Please follow steps below to add them.
cd /root/
wget https://github.com/iredmail/iRedMail/raw/1.0/update/ldap/update-ldap-dovecot-2.3.py
update-ldap-dovecot-2.3.py
, set LDAP server
related settings in this file. For example:# Part of file: update-ldap-dovecot-2.3.py
uri = 'ldap://127.0.0.1:389'
basedn = 'o=domains,dc=example,dc=com'
bind_dn = 'cn=vmailadmin,dc=example,dc=com'
bind_pw = 'password'
You can find required LDAP credential in iRedAdmin config file or
iRedMail.tips
file under your iRedMail installation directory. Using either
cn=Manager,dc=xx,dc=xx
or cn=vmailadmin,dc=xx,dc=xx
as bind dn is ok, both
of them have read-write privilege to update mail accounts.
# python update-ldap-dovecot-2.3.py
iRedMail-0.9.8 integrates mlmmj as mailing list manager, please follow our document below to integrate it:
Attention
mlmmj is a core component since iRedMail-0.9.8.
maddr.email_raw
to store mail address without address extensionMany sender/recipient addresses contain address extension like
user+extension@domain.com
, this is annoying if we try to get top 10
senders/recipients from Amavisd SQL database, because address
user+ext1@domain.com
and user+ext2@domain.com
are considered as different
user. To avoid this issue, we create a SQL trigger to store email address
without address extension in a new column maddr.email_raw
. Please follow
steps below to apply the SQL structure change.
cd /tmp/
wget https://github.com/iredmail/iRedMail/raw/1.0/update/0.9.8/amavisd.mysql
mysql amavisd < amavisd.mysql
Attention
With this change, user can only see other users in same domain. If this is NOT what you expect, you should NOT apply this change.
SOGo is configured by iRedMail to query all users on server while performing account search (e.g. global address book, meeting attendees), this may be not what you expect if you host multiple mail domains and they should not see others on same server. Please follow steps below to fix it.
/etc/sogo/sogo.conf
(Linux/OpenBSD) or
/usr/local/etc/sogo/sogo.conf
(FreeBSD), find lines like below: {
// Used for global address book
type = ldap;
id = global_addressbook;
canAuthenticate = NO;
isAddressBook = YES;
displayName = "Global Address Book";
displayName =
line: bindAsCurrentUser = YES;
Dovecot is IMAP/POP3/Managesieve server, also a SASL auth server for Postfix. If mail domain is disabled, users under this domain are not able to use IMAP/POP3/Managesieve services, but there's a bug in Dovecot SQL query configured by iRedMail, it doesn't check domain status while performing smtp sasl auth. Please follow steps below to fix it.
/etc/dovecot/dovecot-mysql.conf
(Linux/OpenBSD) or
/usr/local/etc/dovecot/dovecot-mysql.conf
(FreeBSD), find the
password_query
line like below:password_query = SELECT password, allow_nets FROM mailbox WHERE username='%u' AND enable%Ls%Lc=1 AND active=1
password_query = SELECT mailbox.password, mailbox.allow_nets \
FROM mailbox,domain \
WHERE mailbox.username='%u' \
AND mailbox.`enable%Ls%Lc`=1 \
AND mailbox.active=1 \
AND mailbox.domain=domain.domain \
AND domain.backupmx=0 \
AND domain.active=1
vmail
databaseWe've made some changes to vmail
database:
mailbox.local_part
. This column was inherited from
PostfixAdmin, but iRedMail didn't use it at all.alias_moderators
to moderators
. Used to store moderators of
both mail alias accounts and mailing lists.domain.maillists
. Used to store per-domain limit of mailing
list accounts. Note: this is majorly used by iRedAdmin-Pro.forwardings.is_maillist
.mailbox.enableimaptls
. Required by Dovecot-2.3.maillists
, used by our new mailing list manager software - mlmmj.Warning
Please backup SQL database vmail
before you run any SQL commands below.
bash /var/vmail/backup/backup_mysql.sh
Download SQL template file used to update SQL database:
cd /root/
wget -O iredmail.mysql https://github.com/iredmail/iRedMail/raw/1.0/update/0.9.8/iredmail.mysql
Connect to MySQL server as MySQL root user, and execute SQL commands:
mysql vmail < /root/iredmail.mysql
maddr.email_raw
to store mail address without address extensionMany sender/recipient addresses contain address extension like
user+extension@domain.com
, this is annoying if we try to get top 10
senders/recipients from Amavisd SQL database, because address
user+ext1@domain.com
and user+ext2@domain.com
should be considered as same
user, but it's not. To avoid this issue, we create a SQL trigger to store email
address without address extension in a new column maddr.email_raw
. Steps:
cd /tmp/
wget https://github.com/iredmail/iRedMail/raw/1.0/update/0.9.8/amavisd.mysql
mysql amavisd < amavisd.mysql
iRedMail-0.9.8 integrates mlmmj as mailing list manager, please follow our document below to integrate it:
Attention
mlmmj is a core component since iRedMail-0.9.8.
Dovecot is IMAP/POP3/Managesieve server, also a SASL auth server for Postfix. If mail domain is disabled, users under this domain are not able to use IMAP/POP3/Managesieve services, but there's a bug in Dovecot SQL query configured by iRedMail, it doesn't check domain status while performing smtp sasl auth. Please follow steps below to fix it.
/etc/dovecot/dovecot-pgsql.conf
(Linux/OpenBSD) or
/usr/local/etc/dovecot/dovecot-pgsql.conf
(FreeBSD), find the
password_query
line like below:password_query = SELECT password, allow_nets FROM mailbox WHERE username='%u' AND enable%Ls%Lc=1 AND active=1
password_query = SELECT mailbox.password, mailbox.allow_nets \
FROM mailbox,domain \
WHERE mailbox.username='%u' \
AND mailbox."enable%Ls%Lc"=1 \
AND mailbox.active=1 \
AND mailbox.domain=domain.domain \
AND domain.backupmx=0 \
AND domain.active=1
vmail
databaseWe've made some changes to vmail
database:
mailbox.local_part
. This column was inherited from
PostfixAdmin, but iRedMail didn't use it at all.alias_moderators
to moderators
. Used to store moderators of
both mail alias accounts and mailing lists.domain.maillists
. Used to store per-domain limit of mailing
list accounts. Note: this is majorly used by iRedAdmin-Pro.forwardings.is_maillist
.mailbox.enableimaptls
. Required by Dovecot-2.3.maillists
, used by our new mailing list manager software - mlmmj.Warning
Please backup SQL database vmail
before you run any SQL commands below.
bash /var/vmail/backup/backup_pgsql.sh
cd /tmp/
wget https://github.com/iredmail/iRedMail/raw/1.0/update/0.9.8/iredmail.pgsql
postgres
user and import the SQL file:postgres
userpgsql
user_postgresql
usersu - postgres
psql -d vmail < /tmp/iredmail.pgsql
maddr.email_raw
to store mail address without address extensionMany sender/recipient addresses contain address extension like
user+extension@domain.com
, this is annoying if we try to get top 10
senders/recipients from Amavisd SQL database, because address
user+ext1@domain.com
and user+ext2@domain.com
should be considered as same
user, but it's not. To avoid this issue, we create a SQL trigger to store email
address without address extension in a new column maddr.email_raw
. Steps:
cd /tmp/
wget https://github.com/iredmail/iRedMail/raw/1.0/update/0.9.8/amavisd.pgsql
# su - postgres
$ psql -U amavisd -d amavisd
sql> \i /tmp/amavisd.pgsql
iRedMail-0.9.8 integrates mlmmj as mailing list manager, please follow our document below to integrate it:
Attention
mlmmj is a core component since iRedMail-0.9.8.