87 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
			
		
		
	
	
			87 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Docker
		
	
	
	
	
	
FROM ubuntu:14.04
 | 
						|
 | 
						|
ENV DEBIAN_FRONTEND noninteractive
 | 
						|
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty main' | tee /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty main' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty-updates main' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty-updates main' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty-updates universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty-updates universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty-updates multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty-updates multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://archive.ubuntu.com/ubuntu/ trusty-backports main restricted universe multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://archive.ubuntu.com/ubuntu/ trusty-backports main restricted universe multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://security.ubuntu.com/ubuntu trusty-security main' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://security.ubuntu.com/ubuntu trusty-security main' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://security.ubuntu.com/ubuntu trusty-security universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://security.ubuntu.com/ubuntu trusty-security universe' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb http://security.ubuntu.com/ubuntu trusty-security multiverse' | tee -a /etc/apt/sources.list
 | 
						|
RUN echo 'deb-src http://security.ubuntu.com/ubuntu trusty-security multiverse' | tee -a /etc/apt/sources.list
 | 
						|
 | 
						|
RUN locale-gen en_GB en_GB.UTF-8 && dpkg-reconfigure locales
 | 
						|
 | 
						|
RUN apt-get update
 | 
						|
 | 
						|
RUN apt-get -y -q autoclean
 | 
						|
RUN apt-get -y -q autoremove
 | 
						|
RUN apt-get clean
 | 
						|
 | 
						|
# prerequisites
 | 
						|
RUN apt-get update
 | 
						|
 | 
						|
# install self-signed ssl certs
 | 
						|
RUN apt-get install -y --force-yes ssl-cert
 | 
						|
 | 
						|
# Install postfix as MTA
 | 
						|
RUN apt-get install -y --force-yes postfix
 | 
						|
 | 
						|
# Install dovecot as IMAP server
 | 
						|
RUN apt-get install -y --force-yes dovecot-imapd
 | 
						|
 | 
						|
# Install OpenDKIM domain signing server
 | 
						|
RUN apt-get install -y --force-yes opendkim
 | 
						|
 | 
						|
# postfix configuration
 | 
						|
ADD ./postfix.main.cf /etc/postfix/main.cf
 | 
						|
ADD ./postfix.master.cf.append /etc/postfix/master-additional.cf
 | 
						|
RUN cat /etc/postfix/master-additional.cf >> /etc/postfix/master.cf
 | 
						|
 | 
						|
# configure settings script
 | 
						|
VOLUME ["/mail_config"]
 | 
						|
COPY process_settings /process_settings
 | 
						|
RUN chmod 755 /process_settings
 | 
						|
 | 
						|
# add user vmail who own all mail folders
 | 
						|
VOLUME ["/vmail"]
 | 
						|
RUN groupadd -g 5000 vmail
 | 
						|
RUN useradd -g vmail -u 5000 vmail -d /vmail -m
 | 
						|
 | 
						|
# dovecot configuration
 | 
						|
ADD ./dovecot.mail /etc/dovecot/conf.d/10-mail.conf
 | 
						|
ADD ./dovecot.ssl /etc/dovecot/conf.d/10-ssl.conf
 | 
						|
ADD ./dovecot.auth /etc/dovecot/conf.d/10-auth.conf
 | 
						|
ADD ./dovecot.master /etc/dovecot/conf.d/10-master.conf
 | 
						|
ADD ./dovecot.lda /etc/dovecot/conf.d/15-lda.conf
 | 
						|
ADD ./dovecot.imap /etc/dovecot/conf.d/20-imap.conf
 | 
						|
# add verbose logging
 | 
						|
#ADD ./internal/dovecot.logging /etc/dovecot/conf.d/10-logging.conf
 | 
						|
 | 
						|
# smtp port for incoming mail
 | 
						|
EXPOSE 25 
 | 
						|
# imap port
 | 
						|
EXPOSE 143
 | 
						|
# smtp port for outgoing
 | 
						|
EXPOSE 587
 | 
						|
 | 
						|
# todo: enable port 587 for outgoing mail, separate ports 25 and 587
 | 
						|
# http://www.synology-wiki.de/index.php/Zusaetzliche_Ports_fuer_Postfix
 | 
						|
 | 
						|
# start necessary services for operation (dovecot -F starts dovecot in the foreground to prevent container exit)
 | 
						|
ENTRYPOINT /process_settings; service rsyslog start; service opendkim start; service postfix start; dovecot -F
 | 
						|
 |