mirror of
https://github.com/zokradonh/kopano-docker
synced 2025-06-06 23:46:24 +00:00
* update to Debian Buster * update webapp container * update kdav image to buster * add some debug commands * use onbuild to specify building of core repository only in one place * remove ca-certificates and git from kdav image * git should not be needed since kdav has a builder stage * ca-certificates is already installed in an earlier stage * upgrade to Debian 10 for Z-Push * switch remaining Debian 9 repos in webapp * use a new major version for the base image * since its now based on buster * add new parameters to the onbuild step * update repos in setup.sh * switch default distribution in create repo script
87 lines
3.3 KiB
Bash
Executable File
87 lines
3.3 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
# define default value for serverhostname and serverport if not passed into container
|
|
KCCONF_SERVERHOSTNAME=${KCCONF_SERVERHOSTNAME:-127.0.0.1}
|
|
KCCONF_SERVERPORT=${KCCONF_SERVERPORT:-237}
|
|
ADDITIONAL_KOPANO_PACKAGES=${ADDITIONAL_KOPANO_PACKAGES:-""}
|
|
ADDITIONAL_KOPANO_WEBAPP_PLUGINS=${ADDITIONAL_KOPANO_WEBAPP_PLUGINS:-""}
|
|
|
|
set -eu # unset variables are errors & non-zero return values exit the whole script
|
|
[ "$DEBUG" ] && set -x
|
|
|
|
# shellcheck source=php/start-helper.sh
|
|
source /kopano/start-helper.sh
|
|
|
|
# Hint: this is not compatible with a read-only container.
|
|
# The general recommendation is to already build a container that has all required packages installed.
|
|
ADDITIONAL_KOPANO_PACKAGES="$ADDITIONAL_KOPANO_PACKAGES $ADDITIONAL_KOPANO_WEBAPP_PLUGINS"
|
|
ADDITIONAL_KOPANO_PACKAGES=$(echo "$ADDITIONAL_KOPANO_PACKAGES" | tr -d '"')
|
|
if [ -n "$(mkdir -p "/var/lib/apt/lists/" 2&> /dev/null)" ]; then
|
|
[ -n "${ADDITIONAL_KOPANO_PACKAGES// }" ] && apt update
|
|
[ -n "${ADDITIONAL_KOPANO_PACKAGES// }" ] && for installpkg in $ADDITIONAL_KOPANO_PACKAGES; do
|
|
# shellcheck disable=SC2016 disable=SC2086
|
|
if [ "$(dpkg-query -W -f='${Status}' $installpkg 2>/dev/null | grep -c 'ok installed')" -eq 0 ]; then
|
|
DEBIAN_FRONTEND=noninteractive apt --assume-yes --no-upgrade install "$installpkg"
|
|
else
|
|
echo "INFO: $installpkg is already installed"
|
|
fi
|
|
done
|
|
else
|
|
echo "Notice: Container is run read-only, skipping package installation."
|
|
echo "If you want to have additional packages installed in the container either:"
|
|
echo "- build your own image with the packages already included"
|
|
echo "- switch the container to 'read_only: false'"
|
|
fi
|
|
|
|
# copy latest config template
|
|
mkdir -p /tmp/webapp/
|
|
for i in /etc/kopano/webapp/*.dist /etc/kopano/webapp/.[^.]*.dist; do
|
|
filename=$(basename -- "$i")
|
|
cp "$i" "/tmp/webapp/${filename%.*}"
|
|
done
|
|
|
|
# Ensure directories exist
|
|
mkdir -p /run/sessions /tmp/webapp /var/lib/kopano-webapp/tmp
|
|
|
|
phpversion=$(dpkg-query --showformat='${Version}' --show php7-mapi)
|
|
echo "Using PHP-Mapi: $phpversion"
|
|
webappversion=$(dpkg-query --showformat='${Version}' --show kopano-webapp)
|
|
echo "Using Kopano WebApp: $webappversion"
|
|
|
|
if [ "$KCCONF_SERVERHOSTNAME" == "127.0.0.1" ]; then
|
|
echo "Kopano WebApp is using the default: connection"
|
|
else
|
|
echo "Kopano WebApp is using an ip connection"
|
|
php_cfg_gen /tmp/webapp/config.php DEFAULT_SERVER "https://${KCCONF_SERVERHOSTNAME}:${KCCONF_SERVERPORT}/kopano"
|
|
fi
|
|
|
|
# configuring webapp from env
|
|
for setting in $(compgen -A variable KCCONF_WEBAPP_); do
|
|
setting2=${setting#KCCONF_WEBAPP_}
|
|
php_cfg_gen /tmp/webapp/config.php "${setting2}" "${!setting}"
|
|
done
|
|
|
|
# configuring webapp plugins from env
|
|
for setting in $(compgen -A variable KCCONF_WEBAPPPLUGIN_); do
|
|
setting2=${setting#KCCONF_WEBAPPPLUGIN_}
|
|
filename="${setting2%%_*}"
|
|
setting3=${setting#KCCONF_WEBAPPPLUGIN_${filename}_}
|
|
identifier="${filename,,}"
|
|
php_cfg_gen /tmp/webapp/config-"$identifier".php "${setting3}" "${!setting}"
|
|
done
|
|
|
|
echo "Ensure config ownership"
|
|
chown -R www-data:www-data /run/sessions /tmp/webapp /var/lib/kopano-webapp/tmp
|
|
|
|
# services need to be aware of the machine-id
|
|
#dockerize \
|
|
# -wait file:///etc/machine-id \
|
|
# -wait file:///var/lib/dbus/machine-id
|
|
|
|
set +u
|
|
# cleaning up env variables
|
|
unset "${!KCCONF_@}"
|
|
echo "Starting php-fpm"
|
|
php-fpm7.3 -F &
|
|
exec /usr/libexec/kopano/kwebd caddy -conf /etc/kweb.cfg
|