2017-04-19 23:14:33 +02:00
|
|
|
#!/bin/sh
|
|
|
|
set -e
|
|
|
|
|
|
|
|
if [ -f /firstrun ]; then
|
|
|
|
echo 'First run of the container. BackupPC will be installed.'
|
|
|
|
echo 'If exist, configuration and data will be reused and upgraded as needed.'
|
|
|
|
|
|
|
|
# Create backuppc user
|
|
|
|
addgroup -S -g ${BACKUPPC_GUID:-1000} backuppc
|
|
|
|
adduser -D -S -h /home/backuppc -G backuppc -u ${BACKUPPC_UUID:-1000} backuppc
|
|
|
|
chown backuppc:backuppc /home/backuppc
|
|
|
|
|
|
|
|
# Generate cryptographic key
|
|
|
|
if [ ! -f /home/backuppc/.ssh/id_rsa ]; then
|
|
|
|
su backuppc -s /bin/sh -c "ssh-keygen -t rsa -N '' -f /home/backuppc/.ssh/id_rsa"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Extract BackupPC
|
|
|
|
cd /root
|
|
|
|
tar xf BackupPC-$BACKUPPC_VERSION.tar.gz
|
|
|
|
cd /root/BackupPC-$BACKUPPC_VERSION
|
|
|
|
|
2017-06-08 17:52:12 +02:00
|
|
|
# Configure WEB UI access
|
|
|
|
configure_admin=""
|
|
|
|
if [ ! -f /etc/backuppc/htpasswd ]; then
|
|
|
|
htpasswd -b -c /etc/backuppc/htpasswd "${BACKUPPC_WEB_USER:-backuppc}" "${BACKUPPC_WEB_PASSWD:-password}"
|
|
|
|
configure_admin="--config-override CgiAdminUsers='${BACKUPPC_WEB_USER:-backuppc}'"
|
|
|
|
elif [ -n "$BACKUPPC_WEB_USER" -a -n "$BACKUPPC_WEB_PASSWD" ]; then
|
|
|
|
touch /etc/backuppc/htpasswd
|
|
|
|
htpasswd -b /etc/backuppc/htpasswd "${BACKUPPC_WEB_USER}" "${BACKUPPC_WEB_PASSWD}"
|
|
|
|
configure_admin="--config-override CgiAdminUsers='$BACKUPPC_WEB_USER'"
|
|
|
|
fi
|
|
|
|
|
2017-04-19 23:14:33 +02:00
|
|
|
# Install BackupPC (existing configuration will be reused and upgraded)
|
2017-04-22 20:17:38 +02:00
|
|
|
perl configure.pl \
|
2017-04-19 23:14:33 +02:00
|
|
|
--batch \
|
|
|
|
--config-dir /etc/backuppc \
|
|
|
|
--cgi-dir /var/www/cgi-bin/BackupPC \
|
|
|
|
--data-dir /data/backuppc \
|
2017-06-26 22:28:07 +02:00
|
|
|
--log-dir /data/backuppc/log \
|
2017-04-19 23:14:33 +02:00
|
|
|
--hostname localhost \
|
|
|
|
--html-dir /var/www/html/BackupPC \
|
|
|
|
--html-dir-url /BackupPC \
|
2017-05-21 13:14:38 +02:00
|
|
|
--install-dir /usr/local/BackupPC \
|
2017-06-08 17:52:12 +02:00
|
|
|
$configure_admin
|
2017-04-19 23:14:33 +02:00
|
|
|
|
|
|
|
# Prepare lighttpd
|
|
|
|
if [ "$USE_SSL" = true ]; then
|
|
|
|
# Generate certificate file as needed
|
|
|
|
cd /etc/lighttpd
|
|
|
|
openssl genrsa -des3 -passout pass:x -out server.pass.key 2048
|
|
|
|
openssl rsa -passin pass:x -in server.pass.key -out server.key
|
|
|
|
openssl req -new -key server.key -out server.csr \
|
|
|
|
-subj "/C=UK/ST=Warwickshire/L=Leamington/O=OrgName/OU=IT Department/CN=example.com"
|
|
|
|
openssl x509 -req -days 365 -in server.csr -signkey server.key -out server.crt
|
|
|
|
cat server.key server.crt > server.pem
|
|
|
|
chown backuppc:backuppc server.pem
|
|
|
|
chmod 0600 server.pem
|
|
|
|
rm -f server.pass.key server.key server.csr server.crt
|
|
|
|
# Reconfigure lighttpd to use ssl
|
|
|
|
echo "ssl.engine = \"enable\"" >> /etc/lighttpd/lighttpd.conf
|
|
|
|
echo "ssl.pemfile = \"/etc/lighttpd/server.pem\"" >> /etc/lighttpd/lighttpd.conf
|
|
|
|
fi
|
|
|
|
touch /var/log/lighttpd/error.log && chown -R backuppc:backuppc /var/log/lighttpd
|
|
|
|
|
2017-04-21 23:57:14 +02:00
|
|
|
# Configure standard mail delivery parameters (may be overriden by backuppc user-wide config)
|
|
|
|
echo "account default" > /etc/msmtprc
|
|
|
|
echo "host ${SMTP_HOST:-mail.example.org}" >> /etc/msmtprc
|
|
|
|
echo "auto_from on" >> /etc/msmtprc
|
|
|
|
if [ "${SMTP_MAIL_DOMAIN:-}" != "" ]; then
|
2017-06-08 13:20:45 +02:00
|
|
|
echo "maildomain ${SMTP_MAIL_DOMAIN}" >> /etc/msmtprc
|
|
|
|
fi
|
2017-04-21 23:57:14 +02:00
|
|
|
|
2017-04-19 23:14:33 +02:00
|
|
|
# Clean
|
|
|
|
rm -rf /root/BackupPC-$BACKUPPC_VERSION.tar.gz /root/BackupPC-$BACKUPPC_VERSION /firstrun
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Exec given CMD in Dockerfile
|
|
|
|
exec "$@"
|