docker-entrypoint.sh 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #!/bin/bash
  2. set -e
  3. # Hard-code env vars to imapsync due to cron not passing them to the perl script
  4. sed -i "/^\$DBUSER/c\\\$DBUSER='${DBUSER}';" /usr/local/bin/imapsync_cron.pl
  5. sed -i "/^\$DBPASS/c\\\$DBPASS='${DBPASS}';" /usr/local/bin/imapsync_cron.pl
  6. sed -i "/^\$DBNAME/c\\\$DBNAME='${DBNAME}';" /usr/local/bin/imapsync_cron.pl
  7. # Create missing directories
  8. [[ ! -d /usr/local/etc/dovecot/sql/ ]] && mkdir -p /usr/local/etc/dovecot/sql/
  9. [[ ! -d /var/vmail/sieve ]] && mkdir -p /var/vmail/sieve
  10. [[ ! -d /etc/sogo ]] && mkdir -p /etc/sogo
  11. # Set Dovecot sql config parameters, escape " in db password
  12. DBPASS=$(echo ${DBPASS} | sed 's/"/\\"/g')
  13. # Create quota dict for Dovecot
  14. cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql.conf
  15. connect = "host=mysql dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
  16. map {
  17. pattern = priv/quota/storage
  18. table = quota2
  19. username_field = username
  20. value_field = bytes
  21. }
  22. map {
  23. pattern = priv/quota/messages
  24. table = quota2
  25. username_field = username
  26. value_field = messages
  27. }
  28. EOF
  29. # Create user and pass dict for Dovecot
  30. cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-mysql.conf
  31. driver = mysql
  32. connect = "host=mysql dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
  33. default_pass_scheme = SSHA256
  34. password_query = SELECT password FROM mailbox WHERE username = '%u' AND domain IN (SELECT domain FROM domain WHERE domain='%d' AND active='1')
  35. user_query = SELECT CONCAT('maildir:/var/vmail/',maildir) AS mail, 5000 AS uid, 5000 AS gid, concat('*:bytes=', quota) AS quota_rule FROM mailbox WHERE username = '%u' AND active = '1'
  36. iterate_query = SELECT username FROM mailbox WHERE active='1';
  37. EOF
  38. # Create global sieve_after script
  39. cat /usr/local/etc/dovecot/sieve_after > /var/vmail/sieve/global.sieve
  40. # Check permissions of vmail directory.
  41. # Do not do this every start-up, it may take a very long time. So we use a stat check here.
  42. if [[ $(stat -c %U /var/vmail/) != "vmail" ]] ; then chown -R vmail:vmail /var/vmail ; fi
  43. # Create random master for SOGo sieve features
  44. RAND_USER=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 16 | head -n 1)
  45. RAND_PASS=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 24 | head -n 1)
  46. echo ${RAND_USER}:$(doveadm pw -s SHA1 -p ${RAND_PASS}) > /usr/local/etc/dovecot/dovecot-master.passwd
  47. echo ${RAND_USER}:${RAND_PASS} > /etc/sogo/sieve.creds
  48. # 401 is user dovecot
  49. if [[ ! -f /mail_crypt/ecprivkey.pem || ! -f /mail_crypt/ecpubkey.pem ]]; then
  50. openssl ecparam -name prime256v1 -genkey | openssl pkey -out /mail_crypt/ecprivkey.pem
  51. openssl pkey -in /mail_crypt/ecprivkey.pem -pubout -out /mail_crypt/ecpubkey.pem
  52. chown 401 /mail_crypt/ecprivkey.pem /mail_crypt/ecpubkey.pem
  53. else
  54. chown 401 /mail_crypt/ecprivkey.pem /mail_crypt/ecpubkey.pem
  55. fi
  56. # Compile sieve scripts
  57. sievec /var/vmail/sieve/global.sieve
  58. sievec /usr/local/lib/dovecot/sieve/report-spam.sieve
  59. sievec /usr/local/lib/dovecot/sieve/report-ham.sieve
  60. # Fix permissions
  61. chown -R vmail:vmail /var/vmail/sieve
  62. exec "$@"