|
@@ -23,7 +23,7 @@ sed -i "s/__DBNAME__/${DBNAME}/g" /usr/local/bin/clean_q_aged.sh
|
|
|
sed -i "s/__LOG_LINES__/${LOG_LINES}/g" /usr/local/bin/trim_logs.sh
|
|
|
|
|
|
# Create missing directories
|
|
|
-[[ ! -d /usr/local/etc/dovecot/sql/ ]] && mkdir -p /usr/local/etc/dovecot/sql/
|
|
|
+[[ ! -d /etc/dovecot/sql/ ]] && mkdir -p /etc/dovecot/sql/
|
|
|
[[ ! -d /var/vmail/_garbage ]] && mkdir -p /var/vmail/_garbage
|
|
|
[[ ! -d /var/vmail/sieve ]] && mkdir -p /var/vmail/sieve
|
|
|
[[ ! -d /etc/sogo ]] && mkdir -p /etc/sogo
|
|
@@ -33,7 +33,7 @@ sed -i "s/__LOG_LINES__/${LOG_LINES}/g" /usr/local/bin/trim_logs.sh
|
|
|
DBPASS=$(echo ${DBPASS} | sed 's/"/\\"/g')
|
|
|
|
|
|
# Create quota dict for Dovecot
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-quota.conf
|
|
|
+cat <<EOF > /etc/dovecot/sql/dovecot-dict-sql-quota.conf
|
|
|
# Autogenerated by mailcow
|
|
|
connect = "host=/var/run/mysqld/mysqld.sock dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
|
|
|
map {
|
|
@@ -51,7 +51,7 @@ map {
|
|
|
EOF
|
|
|
|
|
|
# Create dict used for sieve pre and postfilters
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-sieve_before.conf
|
|
|
+cat <<EOF > /etc/dovecot/sql/dovecot-dict-sql-sieve_before.conf
|
|
|
# Autogenerated by mailcow
|
|
|
connect = "host=/var/run/mysqld/mysqld.sock dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
|
|
|
map {
|
|
@@ -74,7 +74,7 @@ map {
|
|
|
}
|
|
|
EOF
|
|
|
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-sieve_after.conf
|
|
|
+cat <<EOF > /etc/dovecot/sql/dovecot-dict-sql-sieve_after.conf
|
|
|
# Autogenerated by mailcow
|
|
|
connect = "host=/var/run/mysqld/mysqld.sock dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
|
|
|
map {
|
|
@@ -97,20 +97,20 @@ map {
|
|
|
}
|
|
|
EOF
|
|
|
|
|
|
-echo -n ${ACL_ANYONE} > /usr/local/etc/dovecot/acl_anyone
|
|
|
+echo -n ${ACL_ANYONE} > /etc/dovecot/acl_anyone
|
|
|
|
|
|
if [[ "${SKIP_SOLR}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
|
-echo -n 'quota acl zlib listescape mail_crypt mail_crypt_acl mail_log notify' > /usr/local/etc/dovecot/mail_plugins
|
|
|
-echo -n 'quota imap_quota imap_acl acl zlib imap_zlib imap_sieve listescape mail_crypt mail_crypt_acl notify mail_log' > /usr/local/etc/dovecot/mail_plugins_imap
|
|
|
-echo -n 'quota sieve acl zlib listescape mail_crypt mail_crypt_acl' > /usr/local/etc/dovecot/mail_plugins_lmtp
|
|
|
+echo -n 'quota acl zlib listescape mail_crypt mail_crypt_acl mail_log notify' > /etc/dovecot/mail_plugins
|
|
|
+echo -n 'quota imap_quota imap_acl acl zlib imap_zlib imap_sieve listescape mail_crypt mail_crypt_acl notify mail_log' > /etc/dovecot/mail_plugins_imap
|
|
|
+echo -n 'quota sieve acl zlib listescape mail_crypt mail_crypt_acl' > /etc/dovecot/mail_plugins_lmtp
|
|
|
else
|
|
|
-echo -n 'quota acl zlib listescape mail_crypt mail_crypt_acl mail_log notify fts fts_solr' > /usr/local/etc/dovecot/mail_plugins
|
|
|
-echo -n 'quota imap_quota imap_acl acl zlib imap_zlib imap_sieve listescape mail_crypt mail_crypt_acl notify mail_log fts fts_solr' > /usr/local/etc/dovecot/mail_plugins_imap
|
|
|
-echo -n 'quota sieve acl zlib listescape mail_crypt mail_crypt_acl fts fts_solr' > /usr/local/etc/dovecot/mail_plugins_lmtp
|
|
|
+echo -n 'quota acl zlib listescape mail_crypt mail_crypt_acl mail_log notify fts fts_solr' > /etc/dovecot/mail_plugins
|
|
|
+echo -n 'quota imap_quota imap_acl acl zlib imap_zlib imap_sieve listescape mail_crypt mail_crypt_acl notify mail_log fts fts_solr' > /etc/dovecot/mail_plugins_imap
|
|
|
+echo -n 'quota sieve acl zlib listescape mail_crypt mail_crypt_acl fts fts_solr' > /etc/dovecot/mail_plugins_lmtp
|
|
|
fi
|
|
|
-chmod 644 /usr/local/etc/dovecot/mail_plugins /usr/local/etc/dovecot/mail_plugins_imap /usr/local/etc/dovecot/mail_plugins_lmtp /templates/quarantine.tpl
|
|
|
+chmod 644 /etc/dovecot/mail_plugins /etc/dovecot/mail_plugins_imap /etc/dovecot/mail_plugins_lmtp /templates/quarantine.tpl
|
|
|
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-userdb.conf
|
|
|
+cat <<EOF > /etc/dovecot/sql/dovecot-dict-sql-userdb.conf
|
|
|
# Autogenerated by mailcow
|
|
|
driver = mysql
|
|
|
connect = "host=/var/run/mysqld/mysqld.sock dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
|
|
@@ -119,7 +119,7 @@ iterate_query = SELECT username FROM mailbox WHERE active='1';
|
|
|
EOF
|
|
|
|
|
|
# Create pass dict for Dovecot
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-passdb.conf
|
|
|
+cat <<EOF > /etc/dovecot/sql/dovecot-dict-sql-passdb.conf
|
|
|
# Autogenerated by mailcow
|
|
|
driver = mysql
|
|
|
connect = "host=/var/run/mysqld/mysqld.sock dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
|
|
@@ -128,10 +128,10 @@ password_query = SELECT password FROM mailbox WHERE active = '1' AND username =
|
|
|
EOF
|
|
|
|
|
|
# Migrate old sieve_after file
|
|
|
-[[ -f /usr/local/etc/dovecot/sieve_after ]] && mv /usr/local/etc/dovecot/sieve_after /usr/local/etc/dovecot/global_sieve_after
|
|
|
+[[ -f /etc/dovecot/sieve_after ]] && mv /etc/dovecot/sieve_after /etc/dovecot/global_sieve_after
|
|
|
# Create global sieve scripts
|
|
|
-cat /usr/local/etc/dovecot/global_sieve_after > /var/vmail/sieve/global_sieve_after.sieve
|
|
|
-cat /usr/local/etc/dovecot/global_sieve_before > /var/vmail/sieve/global_sieve_before.sieve
|
|
|
+cat /etc/dovecot/global_sieve_after > /var/vmail/sieve/global_sieve_after.sieve
|
|
|
+cat /etc/dovecot/global_sieve_before > /var/vmail/sieve/global_sieve_before.sieve
|
|
|
|
|
|
# Check permissions of vmail/attachments directory.
|
|
|
# Do not do this every start-up, it may take a very long time. So we use a stat check here.
|
|
@@ -147,8 +147,8 @@ rm -rf /var/vmail/mailcow.local/*
|
|
|
RAND_USER=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 16 | head -n 1)
|
|
|
RAND_PASS=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 24 | head -n 1)
|
|
|
|
|
|
-echo ${RAND_USER}@mailcow.local:{SHA1}$(echo -n ${RAND_PASS} | sha1sum | awk '{print $1}') > /usr/local/etc/dovecot/dovecot-master.passwd
|
|
|
-echo ${RAND_USER}@mailcow.local::5000:5000:::: > /usr/local/etc/dovecot/dovecot-master.userdb
|
|
|
+echo ${RAND_USER}@mailcow.local:{SHA1}$(echo -n ${RAND_PASS} | sha1sum | awk '{print $1}') > /etc/dovecot/dovecot-master.passwd
|
|
|
+echo ${RAND_USER}@mailcow.local::5000:5000:::: > /etc/dovecot/dovecot-master.userdb
|
|
|
echo ${RAND_USER}@mailcow.local:${RAND_PASS} > /etc/sogo/sieve.creds
|
|
|
|
|
|
if [[ -z ${MAILDIR_SUB} ]]; then
|
|
@@ -156,7 +156,7 @@ if [[ -z ${MAILDIR_SUB} ]]; then
|
|
|
else
|
|
|
MAILDIR_SUB_SHARED=/${MAILDIR_SUB}
|
|
|
fi
|
|
|
-cat <<EOF > /usr/local/etc/dovecot/shared_namespace.conf
|
|
|
+cat <<EOF > /etc/dovecot/shared_namespace.conf
|
|
|
# Autogenerated by mailcow
|
|
|
namespace {
|
|
|
type = shared
|
|
@@ -172,7 +172,7 @@ if [[ "${ALLOW_ADMIN_EMAIL_LOGIN}" =~ ^([yY][eE][sS]|[yY])+$ ]]; then
|
|
|
# Create random master Password for SOGo 'login as user' via proxy auth
|
|
|
RAND_PASS=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 32 | head -n 1)
|
|
|
echo -n ${RAND_PASS} > /etc/phpfpm/sogo-sso.pass
|
|
|
- cat <<EOF > /usr/local/etc/dovecot/sogo-sso.conf
|
|
|
+ cat <<EOF > /etc/dovecot/sogo-sso.conf
|
|
|
# Autogenerated by mailcow
|
|
|
passdb {
|
|
|
driver = static
|
|
@@ -180,8 +180,8 @@ passdb {
|
|
|
}
|
|
|
EOF
|
|
|
else
|
|
|
- rm -f /usr/local/etc/dovecot/sogo-sso.pass
|
|
|
- rm -f /usr/local/etc/dovecot/sogo-sso.conf
|
|
|
+ rm -f /etc/dovecot/sogo-sso.pass
|
|
|
+ rm -f /etc/dovecot/sogo-sso.conf
|
|
|
fi
|
|
|
|
|
|
# 401 is user dovecot
|
|
@@ -196,20 +196,20 @@ fi
|
|
|
# Compile sieve scripts
|
|
|
sievec /var/vmail/sieve/global_sieve_before.sieve
|
|
|
sievec /var/vmail/sieve/global_sieve_after.sieve
|
|
|
-sievec /usr/local/lib/dovecot/sieve/report-spam.sieve
|
|
|
-sievec /usr/local/lib/dovecot/sieve/report-ham.sieve
|
|
|
+sievec /usr/lib/dovecot/sieve/report-spam.sieve
|
|
|
+sievec /usr/lib/dovecot/sieve/report-ham.sieve
|
|
|
|
|
|
# Fix permissions
|
|
|
-chown root:root /usr/local/etc/dovecot/sql/*.conf
|
|
|
-chown root:dovecot /usr/local/etc/dovecot/sql/dovecot-dict-sql-sieve* /usr/local/etc/dovecot/sql/dovecot-dict-sql-quota*
|
|
|
-chmod 640 /usr/local/etc/dovecot/sql/*.conf
|
|
|
+chown root:root /etc/dovecot/sql/*.conf
|
|
|
+chown root:dovecot /etc/dovecot/sql/dovecot-dict-sql-sieve* /etc/dovecot/sql/dovecot-dict-sql-quota*
|
|
|
+chmod 640 /etc/dovecot/sql/*.conf
|
|
|
chown -R vmail:vmail /var/vmail/sieve
|
|
|
chown -R vmail:vmail /var/volatile
|
|
|
adduser vmail tty
|
|
|
chmod g+rw /dev/console
|
|
|
chown root:tty /dev/console
|
|
|
-chmod +x /usr/local/lib/dovecot/sieve/rspamd-pipe-ham \
|
|
|
- /usr/local/lib/dovecot/sieve/rspamd-pipe-spam \
|
|
|
+chmod +x /usr/lib/dovecot/sieve/rspamd-pipe-ham \
|
|
|
+ /usr/lib/dovecot/sieve/rspamd-pipe-spam \
|
|
|
/usr/local/bin/imapsync_cron.pl \
|
|
|
/usr/local/bin/postlogin.sh \
|
|
|
/usr/local/bin/imapsync \
|
|
@@ -233,7 +233,7 @@ echo '15 4 * * * vmail /usr/local/bin/clean_q_aged.sh >> /dev/console 2>&1' > /e
|
|
|
touch /etc/crontab /etc/cron.*/*
|
|
|
|
|
|
# Clean old PID if any
|
|
|
-[[ -f /usr/local/var/run/dovecot/master.pid ]] && rm /usr/local/var/run/dovecot/master.pid
|
|
|
+[[ -f /var/run/dovecot/master.pid ]] && rm /var/run/dovecot/master.pid
|
|
|
|
|
|
# Clean stopped imapsync jobs
|
|
|
rm -f /tmp/imapsync_busy.lock
|