mirror of
https://github.com/friendica/docker
synced 2025-03-30 03:37:07 +02:00
Use flock for the upgrade process
This commit is contained in:
parent
460e273adc
commit
003826bcd3
7 changed files with 686 additions and 616 deletions
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
|
@ -69,107 +69,117 @@ if expr "$1" : "apache" 1>/dev/null || [ "$1" = "php-fpm" ]; then
|
||||||
} > /usr/local/etc/php/conf.d/redis-session.ini
|
} > /usr/local/etc/php/conf.d/redis-session.ini
|
||||||
fi
|
fi
|
||||||
|
|
||||||
installed_version="0.0.0.0"
|
# If another process is syncing the html folder, wait for
|
||||||
if [ -f /var/www/html/VERSION ]; then
|
# it to be done, then escape initialization.
|
||||||
installed_version="$(cat /var/www/html/VERSION)"
|
(
|
||||||
fi
|
if ! flock -n 9; then
|
||||||
|
# If we couldn't get it immediately, show a message, then wait for real
|
||||||
image_version="0.0.0.0"
|
echo "Another process is initializing Nextcloud. Waiting..."
|
||||||
if [ -f /usr/src/friendica/VERSION ]; then
|
flock 9
|
||||||
image_version="$(cat /usr/src/friendica/VERSION)"
|
|
||||||
else
|
|
||||||
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# no downgrading possible
|
|
||||||
if version_greater "$installed_version" "$image_version"; then
|
|
||||||
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
# check it just in case the version is greater or if we force the upgrade
|
|
||||||
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
|
||||||
echo "Initializing Friendica $image_version ..."
|
|
||||||
|
|
||||||
if [ "$installed_version" != "0.0.0.0" ]; then
|
|
||||||
echo "Upgrading Friendica from $installed_version ..."
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$(id -u)" -eq 0 ]; then
|
installed_version="0.0.0.0"
|
||||||
rsync_options="-rlDog --chown=www-data:www-data"
|
if [ -f /var/www/html/VERSION ]; then
|
||||||
|
installed_version="$(cat /var/www/html/VERSION)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
image_version="0.0.0.0"
|
||||||
|
if [ -f /usr/src/friendica/VERSION ]; then
|
||||||
|
image_version="$(cat /usr/src/friendica/VERSION)"
|
||||||
else
|
else
|
||||||
rsync_options="-rlD"
|
echo "No new Friendica sources found (enable FRIENDICA_UPGRADE for new sources)"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
# no downgrading possible
|
||||||
|
if version_greater "$installed_version" "$image_version"; then
|
||||||
# Update docker-based config files, but never delete other config files
|
echo "Can't copy Friendica sources because the version of the data ($installed_version) is higher than the docker image ($image_version)"
|
||||||
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
exit 1
|
||||||
|
|
||||||
# In case there is no .htaccess, copy it from the default dist file
|
|
||||||
if [ ! -f "/var/www/html/.htaccess" ]; then
|
|
||||||
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -d /var/www/html/view/smarty3 ]; then
|
# check it just in case the version is greater or if we force the upgrade
|
||||||
chmod -R 777 /var/www/html/view/smarty3
|
if version_greater "$image_version" "$installed_version" || [ "${FRIENDICA_UPGRADE:-false}" = "true" ]; then
|
||||||
fi
|
echo "Initializing Friendica $image_version ..."
|
||||||
echo "Initializing finished"
|
|
||||||
|
|
||||||
# install
|
if [ "$installed_version" != "0.0.0.0" ]; then
|
||||||
if [ "$installed_version" = "0.0.0.0" ]; then
|
echo "Upgrading Friendica from $installed_version ..."
|
||||||
echo "New Friendica instance"
|
|
||||||
|
|
||||||
file_env FRIENDICA_ADMIN_MAIL
|
|
||||||
|
|
||||||
file_env MYSQL_DATABASE
|
|
||||||
file_env MYSQL_USER
|
|
||||||
file_env MYSQL_PASSWORD
|
|
||||||
|
|
||||||
install=false
|
|
||||||
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
|
||||||
echo "Installation with environment variables"
|
|
||||||
|
|
||||||
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
|
||||||
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
|
||||||
MYSQL_PORT=${MYSQL_PORT:-3306}
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
|
||||||
|
|
||||||
# shellcheck disable=SC2016
|
|
||||||
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
|
||||||
install=true
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$install" = true ]; then
|
if [ "$(id -u)" -eq 0 ]; then
|
||||||
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
rsync_options="-rlDog --chown=www-data:www-data"
|
||||||
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
|
||||||
|
|
||||||
echo "Starting Friendica installation ..."
|
|
||||||
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
|
||||||
|
|
||||||
rm -fr /var/www/html/view/smarty3/compiled
|
|
||||||
|
|
||||||
# load other config files (*.config.php) to the config folder
|
|
||||||
if [ -d "/usr/src/config" ]; then
|
|
||||||
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "Installation finished"
|
|
||||||
else
|
|
||||||
echo "[ERROR] Waited 300 seconds, no response" >&2
|
|
||||||
fi
|
|
||||||
else
|
else
|
||||||
echo "Running web-based installer on first connect!"
|
rsync_options="-rlD"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rsync $rsync_options --delete --exclude-from=/upgrade.exclude /usr/src/friendica/ /var/www/html/
|
||||||
|
|
||||||
|
# Update docker-based config files, but never delete other config files
|
||||||
|
rsync $rsync_options --update --exclude=/addon.config.php --exclude=/local.config.php /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
|
||||||
|
# In case there is no .htaccess, copy it from the default dist file
|
||||||
|
if [ ! -f "/var/www/html/.htaccess" ]; then
|
||||||
|
cp "/var/www/html/.htaccess-dist" "/var/www/html/.htaccess"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -d /var/www/html/view/smarty3 ]; then
|
||||||
|
chmod -R 777 /var/www/html/view/smarty3
|
||||||
|
fi
|
||||||
|
echo "Initializing finished"
|
||||||
|
|
||||||
|
# install
|
||||||
|
if [ "$installed_version" = "0.0.0.0" ]; then
|
||||||
|
echo "New Friendica instance"
|
||||||
|
|
||||||
|
file_env FRIENDICA_ADMIN_MAIL
|
||||||
|
|
||||||
|
file_env MYSQL_DATABASE
|
||||||
|
file_env MYSQL_USER
|
||||||
|
file_env MYSQL_PASSWORD
|
||||||
|
|
||||||
|
install=false
|
||||||
|
if [ -n "${MYSQL_DATABASE+x}" ] && [ -n "${MYSQL_PASSWORD+x}" ] && [ -n "${MYSQL_HOST+x}" ] && [ -n "${MYSQL_USER+x}" ] && [ -n "${FRIENDICA_ADMIN_MAIL+x}" ] && [ -n "${FRIENDICA_URL+x}" ]; then
|
||||||
|
echo "Installation with environment variables"
|
||||||
|
|
||||||
|
FRIENDICA_TZ=${FRIENDICA_TZ:-America/New_York}
|
||||||
|
FRIENDICA_LANG=${FRIENDICA_LANG:-en}
|
||||||
|
MYSQL_PORT=${MYSQL_PORT:-3306}
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options='-s --dbhost "'$MYSQL_HOST'" --dbport "'$MYSQL_PORT'" --dbdata "'$MYSQL_DATABASE'" --dbuser "'$MYSQL_USER'" --dbpass "'$MYSQL_PASSWORD'"'
|
||||||
|
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
install_options=$install_options' --admin "'$FRIENDICA_ADMIN_MAIL'" --tz "'$FRIENDICA_TZ'" --lang "'$FRIENDICA_LANG'" --url "'$FRIENDICA_URL'"'
|
||||||
|
install=true
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$install" = true ]; then
|
||||||
|
echo "Waiting for MySQL $MYSQL_HOST initialization..."
|
||||||
|
if run_as "php /var/www/html/bin/wait-for-connection $MYSQL_HOST ${MYSQL_PORT:-3306} 300"; then
|
||||||
|
|
||||||
|
echo "Starting Friendica installation ..."
|
||||||
|
run_as "php /var/www/html/bin/console.php autoinstall $install_options"
|
||||||
|
|
||||||
|
rm -fr /var/www/html/view/smarty3/compiled
|
||||||
|
|
||||||
|
# load other config files (*.config.php) to the config folder
|
||||||
|
if [ -d "/usr/src/config" ]; then
|
||||||
|
rsync $rsync_options --ignore-existing /usr/src/friendica/config/ /var/www/html/config/
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Installation finished"
|
||||||
|
else
|
||||||
|
echo "[ERROR] Waited 300 seconds, no response" >&2
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
echo "Running web-based installer on first connect!"
|
||||||
|
fi
|
||||||
|
# upgrade
|
||||||
|
else
|
||||||
|
echo "Upgrading Friendica ..."
|
||||||
|
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
||||||
|
echo "Upgrading finished"
|
||||||
fi
|
fi
|
||||||
# upgrade
|
|
||||||
else
|
|
||||||
echo "Upgrading Friendica ..."
|
|
||||||
run_as 'php /var/www/html/bin/console.php dbstructure update -f'
|
|
||||||
echo "Upgrading finished"
|
|
||||||
fi
|
fi
|
||||||
fi
|
) 9> /var/www/html/nextcloud-init-sync.lock
|
||||||
fi
|
fi
|
||||||
|
|
||||||
exec "$@"
|
exec "$@"
|
||||||
|
|
Loading…
Add table
Reference in a new issue