Dockerfile 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143
  1. FROM debian:stretch-slim
  2. LABEL maintainer "Andre Peters <andre.peters@servercow.de>"
  3. ARG DEBIAN_FRONTEND=noninteractive
  4. ENV LC_ALL C
  5. ENV DOVECOT_VERSION 2.3.4
  6. ENV PIGEONHOLE_VERSION 0.5.4
  7. RUN apt-get update && apt-get -y --no-install-recommends install \
  8. automake \
  9. autotools-dev \
  10. build-essential \
  11. ca-certificates \
  12. cpanminus \
  13. curl \
  14. default-libmysqlclient-dev \
  15. dnsutils \
  16. gettext \
  17. jq \
  18. libjson-webtoken-perl \
  19. libcgi-pm-perl \
  20. libcrypt-openssl-rsa-perl \
  21. libdata-uniqid-perl \
  22. libhtml-parser-perl \
  23. libmail-imapclient-perl \
  24. libparse-recdescent-perl \
  25. libsys-meminfo-perl \
  26. libtest-mockobject-perl \
  27. libwww-perl \
  28. libauthen-ntlm-perl \
  29. libbz2-dev \
  30. libcrypt-ssleay-perl \
  31. libcurl4-openssl-dev \
  32. libdbd-mysql-perl \
  33. libdbi-perl \
  34. libdigest-hmac-perl \
  35. libexpat1-dev \
  36. libfile-copy-recursive-perl \
  37. libio-compress-perl \
  38. libio-socket-inet6-perl \
  39. libio-socket-ssl-perl \
  40. libio-tee-perl \
  41. libipc-run-perl \
  42. libldap2-dev \
  43. liblockfile-simple-perl \
  44. liblz-dev \
  45. liblz4-dev \
  46. liblzma-dev \
  47. libmodule-scandeps-perl \
  48. libnet-ssleay-perl \
  49. libpam-dev \
  50. libpar-packer-perl \
  51. libreadonly-perl \
  52. libssl-dev \
  53. libterm-readkey-perl \
  54. libtest-pod-perl \
  55. libtest-simple-perl \
  56. libtry-tiny-perl \
  57. libunicode-string-perl \
  58. libproc-processtable-perl \
  59. libtest-nowarnings-perl \
  60. libtest-deep-perl \
  61. libtest-warn-perl \
  62. libregexp-common-perl \
  63. liburi-perl \
  64. lzma-dev \
  65. make \
  66. mysql-client \
  67. procps \
  68. supervisor \
  69. cron \
  70. redis-server \
  71. syslog-ng \
  72. syslog-ng-core \
  73. syslog-ng-mod-redis \
  74. && rm -rf /var/lib/apt/lists/*
  75. RUN curl https://www.dovecot.org/releases/2.3/dovecot-$DOVECOT_VERSION.tar.gz | tar xvz \
  76. && cd dovecot-$DOVECOT_VERSION \
  77. && ./configure --with-solr --with-mysql --with-ldap --with-lzma --with-lz4 --with-ssl=openssl --with-notify=inotify --with-storages=mdbox,sdbox,maildir,mbox,imapc,pop3c --with-bzlib --with-zlib --enable-hardening \
  78. && make -j3 \
  79. && make install \
  80. && make clean \
  81. && cd .. && rm -rf dovecot-$DOVECOT_VERSION \
  82. && curl https://pigeonhole.dovecot.org/releases/2.3/dovecot-2.3-pigeonhole-$PIGEONHOLE_VERSION.tar.gz | tar xvz \
  83. && cd dovecot-2.3-pigeonhole-$PIGEONHOLE_VERSION \
  84. && ./configure \
  85. && make -j3 \
  86. && make install \
  87. && make clean \
  88. && cd .. \
  89. && rm -rf dovecot-2.3-pigeonhole-$PIGEONHOLE_VERSION
  90. RUN cpanm Data::Uniqid Mail::IMAPClient String::Util
  91. RUN echo '* * * * * root /usr/local/bin/imapsync_cron.pl' > /etc/cron.d/imapsync
  92. RUN echo '30 3 * * * vmail /usr/local/bin/doveadm quota recalc -A' > /etc/cron.d/dovecot-sync
  93. RUN echo '* * * * * vmail /usr/local/bin/trim_logs.sh >> /dev/console 2>&1' > /etc/cron.d/trim_logs
  94. RUN echo '25 * * * * vmail /usr/local/bin/maildir_gc.sh >> /dev/console 2>&1' > /etc/cron.d/maildir_gc
  95. RUN echo '30 1 * * * root /usr/local/bin/sa-rules.sh >> /dev/console 2>&1' > /etc/cron.d/sa-rules
  96. RUN echo '0 2 * * * root /usr/bin/curl http://solr:8983/solr/dovecot/update?optimize=true >> /dev/console 2>&1' > /etc/cron.d/solr-optimize
  97. COPY trim_logs.sh /usr/local/bin/trim_logs.sh
  98. COPY syslog-ng.conf /etc/syslog-ng/syslog-ng.conf
  99. COPY imapsync /usr/local/bin/imapsync
  100. COPY postlogin.sh /usr/local/bin/postlogin.sh
  101. COPY imapsync_cron.pl /usr/local/bin/imapsync_cron.pl
  102. COPY report-spam.sieve /usr/local/lib/dovecot/sieve/report-spam.sieve
  103. COPY report-ham.sieve /usr/local/lib/dovecot/sieve/report-ham.sieve
  104. COPY rspamd-pipe-ham /usr/local/lib/dovecot/sieve/rspamd-pipe-ham
  105. COPY rspamd-pipe-spam /usr/local/lib/dovecot/sieve/rspamd-pipe-spam
  106. COPY sa-rules.sh /usr/local/bin/sa-rules.sh
  107. COPY maildir_gc.sh /usr/local/bin/maildir_gc.sh
  108. COPY docker-entrypoint.sh /
  109. COPY supervisord.conf /etc/supervisor/supervisord.conf
  110. COPY stop-supervisor.sh /usr/local/sbin/stop-supervisor.sh
  111. RUN chmod +x /usr/local/lib/dovecot/sieve/rspamd-pipe-ham \
  112. /usr/local/lib/dovecot/sieve/rspamd-pipe-spam \
  113. /usr/local/bin/imapsync_cron.pl \
  114. /usr/local/bin/postlogin.sh \
  115. /usr/local/bin/imapsync \
  116. /usr/local/bin/trim_logs.sh \
  117. /usr/local/bin/sa-rules.sh \
  118. /usr/local/bin/maildir_gc.sh \
  119. /usr/local/sbin/stop-supervisor.sh
  120. RUN groupadd -g 5000 vmail \
  121. && groupadd -g 401 dovecot \
  122. && groupadd -g 402 dovenull \
  123. && useradd -g vmail -u 5000 vmail -d /var/vmail \
  124. && useradd -c "Dovecot unprivileged user" -d /dev/null -u 401 -g dovecot -s /bin/false dovecot \
  125. && useradd -c "Dovecot login user" -d /dev/null -u 402 -g dovenull -s /bin/false dovenull
  126. RUN touch /etc/default/locale
  127. RUN apt-get purge -y build-essential automake autotools-dev default-libmysqlclient-dev libbz2-dev libcurl4-openssl-dev libexpat1-dev liblz-dev liblz4-dev liblzma-dev libpam-dev libssl-dev lzma-dev \
  128. && apt-get autoremove --purge -y
  129. ENTRYPOINT ["/docker-entrypoint.sh"]
  130. CMD exec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf
  131. RUN rm -rf \
  132. /tmp/* \
  133. /var/tmp/*