FROM debian:bullseye-slim as build LABEL maintainer "Andre Peters " ARG DEBIAN_FRONTEND=noninteractive ARG DOVECOT=2.3.19.1 ARG FLATCURVE=v0.3.2 ARG XAPIAN=1.4.21 ENV LC_ALL C # Add groups and users before installing Dovecot to not break compatibility RUN touch /etc/default/locale \ && apt-get update \ && apt-get -y --no-install-recommends install \ apt-transport-https \ ca-certificates \ cpanminus \ curl \ dnsutils \ dirmngr \ gettext \ gnupg2 \ jq \ libauthen-ntlm-perl \ libcgi-pm-perl \ libcrypt-openssl-rsa-perl \ libcrypt-ssleay-perl \ libdata-uniqid-perl \ libdbd-mysql-perl \ libdbi-perl \ libdigest-hmac-perl \ libdist-checkconflicts-perl \ libencode-imaputf7-perl \ libfile-copy-recursive-perl \ libfile-tail-perl \ libhtml-parser-perl \ libio-compress-perl \ libio-socket-inet6-perl \ libio-socket-ssl-perl \ libio-tee-perl \ libipc-run-perl \ libjson-webtoken-perl \ liblockfile-simple-perl \ libmail-imapclient-perl \ libmodule-implementation-perl \ libmodule-scandeps-perl \ libnet-ssleay-perl \ libpackage-stash-perl \ libpackage-stash-xs-perl \ libpar-packer-perl \ libparse-recdescent-perl \ libproc-processtable-perl \ libreadonly-perl \ libregexp-common-perl \ libsys-meminfo-perl \ libterm-readkey-perl \ libtest-deep-perl \ libtest-fatal-perl \ libtest-mock-guard-perl \ libtest-mockobject-perl \ libtest-nowarnings-perl \ libtest-pod-perl \ libtest-requires-perl \ libtest-simple-perl \ libtest-warn-perl \ libtry-tiny-perl \ libunicode-string-perl \ liburi-perl \ libwww-perl \ libstemmer-dev \ libexttextcat-dev \ libldap-dev \ libghc-bzlib-dev \ lua-sql-mysql \ liblz4-dev \ libzstd-dev \ lua-socket \ mariadb-client \ procps \ python3-pip \ redis-server \ supervisor \ syslog-ng \ syslog-ng-core \ syslog-ng-mod-redis \ wget \ git \ bison \ flex \ build-essential \ autoconf \ automake \ libtool \ make \ libxapian-dev \ default-libmysqlclient-dev \ libicu-dev \ zlib1g-dev \ pkg-config \ libsqlite3-dev \ liblua5.3-dev \ && dpkgArch="$(dpkg --print-architecture | awk -F- '{ print $NF }')" \ && wget -O /usr/local/bin/gosu "https://github.com/tianon/gosu/releases/download/$GOSU_VERSION/gosu-$dpkgArch" \ && chmod +x /usr/local/bin/gosu \ && gosu nobody true # && apt-key adv --fetch-keys https://repo.dovecot.org/DOVECOT-REPO-GPG \ # && echo "deb https://repo.dovecot.org/ce-${DOVECOT}/debian/bullseye bullseye main" > /etc/apt/sources.list.d/dovecot.list \ # && apt-get update \ # && apt-get -y --no-install-recommends install \ # dovecot-lua \ # dovecot-managesieved \ # dovecot-sieve \ # dovecot-lmtpd \ # dovecot-ldap \ # dovecot-mysql \ # dovecot-core \ # dovecot-pop3d \ # dovecot-imapd \ # dovecot-dev RUN cd /tmp && git clone --depth 1 --branch ${DOVECOT} https://github.com/dovecot/core.git dovecot/core && cd dovecot/core \ && ./autogen.sh \ && PANDOC=false ./configure --prefix=/usr --sysconfdir=/etc --localstatedir=/var --with-ssldir=/etc/ssl --enable-maintainer-mode --with-sql=yes --with-lua=yes --with-mysql --with-ldap --with-zstd --with-lz4 --with-ssl=openssl --with-notify=inotify --with-bzlib --with-zlib --enable-hardening --with-stemmer --with-textcat --with-icu \ && make -j6 \ && make install \ && make clean RUN cd /tmp && git clone --depth 1 --branch release-0.5 https://github.com/dovecot/pigeonhole dovecot/pigeonhole && cd dovecot/pigeonhole \ && ./autogen.sh \ && ./configure --with-dovecot=/usr/lib/dovecot --with-managesieve\ && make -j6 \ && make install \ && make clean RUN cd /tmp && wget https://oligarchy.co.uk/xapian/${XAPIAN}/xapian-core-${XAPIAN}.tar.xz && tar xf xapian-core-${XAPIAN}.tar.xz && cd xapian-core-${XAPIAN} \ && ./configure --prefix=/usr/local/xapian \ && make -j6 \ && make install \ && make clean RUN cd /tmp && git clone --depth 1 --branch ${FLATCURVE} https://github.com/slusarz/dovecot-fts-flatcurve.git dovecot/flatcurve && cd dovecot/flatcurve \ && ./autogen.sh \ && ./configure --with-dovecot=/usr/lib/dovecot \ && make -j6 \ && make install \ && make clean FROM debian:bullseye-slim RUN groupadd -g 5000 vmail \ && groupadd -g 401 dovecot \ && groupadd -g 402 dovenull \ && groupadd -g 999 sogo \ && usermod -a -G sogo nobody \ && useradd -g vmail -u 5000 vmail -d /var/vmail \ && useradd -c "Dovecot unprivileged user" -d /dev/null -u 401 -g dovecot -s /bin/false dovecot \ && useradd -c "Dovecot login user" -d /dev/null -u 402 -g dovenull -s /bin/false dovenull \ && apt update && apt install lua-socket \ mariadb-client \ libstemmer-dev \ libexttextcat-dev \ libicu-dev \ libxapian-dev \ libsqlite3-dev \ liblua5.3-dev \ lua-sql-mysql \ libldap-dev \ procps \ python3-pip \ redis-server \ supervisor \ syslog-ng \ syslog-ng-core \ syslog-ng-mod-redis \ cpanminus \ curl \ libauthen-ntlm-perl \ libcgi-pm-perl \ libcrypt-openssl-rsa-perl \ libcrypt-ssleay-perl \ libdata-uniqid-perl \ libdbd-mysql-perl \ libdbi-perl \ libdigest-hmac-perl \ libdist-checkconflicts-perl \ libencode-imaputf7-perl \ libfile-copy-recursive-perl \ libfile-tail-perl \ libhtml-parser-perl \ libio-compress-perl \ libio-socket-inet6-perl \ libio-socket-ssl-perl \ libio-tee-perl \ libipc-run-perl \ libjson-webtoken-perl \ liblockfile-simple-perl \ libmail-imapclient-perl \ libmodule-implementation-perl \ libmodule-scandeps-perl \ libnet-ssleay-perl \ libpackage-stash-perl \ libpackage-stash-xs-perl \ libpar-packer-perl \ libparse-recdescent-perl \ libproc-processtable-perl \ libreadonly-perl \ libregexp-common-perl \ libsys-meminfo-perl \ libterm-readkey-perl \ libtest-deep-perl \ libtest-fatal-perl \ libtest-mock-guard-perl \ libtest-mockobject-perl \ libtest-nowarnings-perl \ libtest-pod-perl \ libtest-requires-perl \ libtest-simple-perl \ libtest-warn-perl \ libtry-tiny-perl \ libunicode-string-perl \ liburi-perl \ libwww-perl \ dnsutils \ gettext-base -y --no-install-recommends \ && pip3 install mysql-connector-python html2text jinja2 redis COPY --from=build /usr/lib/dovecot /usr/lib/dovecot COPY --from=build /usr/bin/doveconf /usr/bin/doveconf COPY --from=build /usr/bin/doveadm /usr/bin/doveadm COPY --from=build /usr/bin/dovecot-sysreport /usr/bin/dovecot-sysreport COPY --from=build /usr/sbin/dovecot /usr/sbin/dovecot COPY --from=build /usr/libexec/dovecot/ /usr/libexec/dovecot/ COPY --from=build /usr/local/bin /usr/local/bin COPY --from=build /usr/local/xapian/ /usr/local/xapian COPY trim_logs.sh /usr/local/bin/trim_logs.sh COPY clean_q_aged.sh /usr/local/bin/clean_q_aged.sh COPY syslog-ng.conf /etc/syslog-ng/syslog-ng.conf COPY syslog-ng-redis_slave.conf /etc/syslog-ng/syslog-ng-redis_slave.conf COPY imapsync /usr/local/bin/imapsync COPY imapsync_runner.pl /usr/local/bin/imapsync_runner.pl COPY report-spam.sieve /usr/lib/dovecot/sieve/report-spam.sieve COPY report-ham.sieve /usr/lib/dovecot/sieve/report-ham.sieve COPY rspamd-pipe-ham /usr/lib/dovecot/sieve/rspamd-pipe-ham COPY rspamd-pipe-spam /usr/lib/dovecot/sieve/rspamd-pipe-spam COPY sa-rules.sh /usr/local/bin/sa-rules.sh COPY maildir_gc.sh /usr/local/bin/maildir_gc.sh COPY docker-entrypoint.sh / COPY supervisord.conf /etc/supervisor/supervisord.conf COPY stop-supervisor.sh /usr/local/sbin/stop-supervisor.sh COPY quarantine_notify.py /usr/local/bin/quarantine_notify.py COPY quota_notify.py /usr/local/bin/quota_notify.py COPY repl_health.sh /usr/local/bin/repl_health.sh ENTRYPOINT ["/docker-entrypoint.sh"] CMD exec /usr/bin/supervisord -c /etc/supervisor/supervisord.conf