docker-entrypoint.sh 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  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-quota.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 dict used for sieve pre and postfilters
  30. cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-sieve_before.conf
  31. connect = "host=mysql dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
  32. map {
  33. pattern = priv/sieve/name/\$script_name
  34. table = sieve_before
  35. username_field = username
  36. value_field = id
  37. fields {
  38. script_name = \$script_name
  39. }
  40. }
  41. map {
  42. pattern = priv/sieve/data/\$id
  43. table = sieve_before
  44. username_field = username
  45. value_field = script_data
  46. fields {
  47. id = \$id
  48. }
  49. }
  50. EOF
  51. cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-sieve_after.conf
  52. connect = "host=mysql dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
  53. map {
  54. pattern = priv/sieve/name/\$script_name
  55. table = sieve_after
  56. username_field = username
  57. value_field = id
  58. fields {
  59. script_name = \$script_name
  60. }
  61. }
  62. map {
  63. pattern = priv/sieve/data/\$id
  64. table = sieve_after
  65. username_field = username
  66. value_field = script_data
  67. fields {
  68. id = \$id
  69. }
  70. }
  71. EOF
  72. # Create user and pass dict for Dovecot
  73. cat <<EOF > /usr/local/etc/dovecot/sql/dovecot-dict-sql-passdb.conf
  74. driver = mysql
  75. connect = "host=mysql dbname=${DBNAME} user=${DBUSER} password=${DBPASS}"
  76. default_pass_scheme = SSHA256
  77. password_query = SELECT password FROM mailbox WHERE username = '%u' AND domain IN (SELECT domain FROM domain WHERE domain='%d' AND active='1') AND JSON_EXTRACT(attributes, "$.force_pw_update") NOT LIKE '%1%'
  78. 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'
  79. iterate_query = SELECT username FROM mailbox WHERE active='1';
  80. EOF
  81. # Create global sieve_after script
  82. cat /usr/local/etc/dovecot/sieve_after > /var/vmail/sieve/global.sieve
  83. # Check permissions of vmail directory.
  84. # Do not do this every start-up, it may take a very long time. So we use a stat check here.
  85. if [[ $(stat -c %U /var/vmail/) != "vmail" ]] ; then chown -R vmail:vmail /var/vmail ; fi
  86. # Create random master for SOGo sieve features
  87. RAND_USER=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 16 | head -n 1)
  88. RAND_PASS=$(cat /dev/urandom | tr -dc 'a-z0-9' | fold -w 24 | head -n 1)
  89. echo ${RAND_USER}:$(doveadm pw -s SHA1 -p ${RAND_PASS}) > /usr/local/etc/dovecot/dovecot-master.passwd
  90. echo ${RAND_USER}:${RAND_PASS} > /etc/sogo/sieve.creds
  91. # 401 is user dovecot
  92. if [[ ! -f /mail_crypt/ecprivkey.pem || ! -f /mail_crypt/ecpubkey.pem ]]; then
  93. openssl ecparam -name prime256v1 -genkey | openssl pkey -out /mail_crypt/ecprivkey.pem
  94. openssl pkey -in /mail_crypt/ecprivkey.pem -pubout -out /mail_crypt/ecpubkey.pem
  95. chown 401 /mail_crypt/ecprivkey.pem /mail_crypt/ecpubkey.pem
  96. else
  97. chown 401 /mail_crypt/ecprivkey.pem /mail_crypt/ecpubkey.pem
  98. fi
  99. # Compile sieve scripts
  100. sievec /var/vmail/sieve/global.sieve
  101. sievec /usr/local/lib/dovecot/sieve/report-spam.sieve
  102. sievec /usr/local/lib/dovecot/sieve/report-ham.sieve
  103. # Fix permissions
  104. chown -R vmail:vmail /var/vmail/sieve
  105. # Fix more than 1 hardlink issue
  106. touch /etc/crontab /etc/cron.*/*
  107. # Clean old PID if any
  108. [[ -f /usr/local/var/run/dovecot/master.pid ]] && rm /usr/local/var/run/dovecot/master.pid
  109. exec "$@"