diff options
Diffstat (limited to '.docker/app/startup.sh')
-rw-r--r-- | .docker/app/startup.sh | 153 |
1 files changed, 153 insertions, 0 deletions
diff --git a/.docker/app/startup.sh b/.docker/app/startup.sh new file mode 100644 index 000000000..134428276 --- /dev/null +++ b/.docker/app/startup.sh @@ -0,0 +1,153 @@ +#!/bin/sh -e + +while ! pg_isready -h $TTRSS_DB_HOST -U $TTRSS_DB_USER; do + echo waiting until $TTRSS_DB_HOST is ready... + sleep 3 +done + +# We don't need those here (HTTP_HOST would cause false SELF_URL_PATH check failures) +unset HTTP_PORT +unset HTTP_HOST + +if ! id app >/dev/null 2>&1; then + addgroup -g $OWNER_GID app + adduser -D -h /var/www/html -G app -u $OWNER_UID app +fi + +update-ca-certificates || true + +DST_DIR=/var/www/html/tt-rss + +[ -e $DST_DIR ] && rm -f $DST_DIR/.app_is_ready + +export PGPASSWORD=$TTRSS_DB_PASS + +[ ! -e /var/www/html/index.php ] && cp ${SCRIPT_ROOT}/index.php /var/www/html + +if [ ! -d $DST_DIR ]; then + mkdir -p $DST_DIR + chown $OWNER_UID:$OWNER_GID $DST_DIR + + sudo -u app rsync -a \ + $SRC_DIR/ $DST_DIR/ +else + chown -R $OWNER_UID:$OWNER_GID $DST_DIR + + sudo -u app rsync -a --delete \ + --exclude /cache \ + --exclude /lock \ + --exclude /feed-icons \ + --exclude /plugins/af_comics/filters.local \ + --exclude /plugins.local \ + --exclude /templates.local \ + --exclude /themes.local \ + $SRC_DIR/ $DST_DIR/ + + sudo -u app rsync -a --delete \ + $SRC_DIR/plugins.local/nginx_xaccel \ + $DST_DIR/plugins.local/nginx_xaccel +fi + +for d in cache lock feed-icons plugins.local themes.local; do + sudo -u app mkdir -p $DST_DIR/$d +done + +for d in cache lock feed-icons; do + chmod 777 $DST_DIR/$d + find $DST_DIR/$d -type f -exec chmod 666 {} \; +done + +sudo -u app cp ${SCRIPT_ROOT}/config.docker.php $DST_DIR/config.php +chmod 644 $DST_DIR/config.php + +chown -R $OWNER_UID:$OWNER_GID $DST_DIR \ + /var/log/php81 + +if [ -z "$TTRSS_NO_STARTUP_PLUGIN_UPDATES" ]; then + echo updating all local plugins... + + find $DST_DIR/plugins.local -mindepth 1 -maxdepth 1 -type d | while read PLUGIN; do + if [ -d $PLUGIN/.git ]; then + echo updating $PLUGIN... + + cd $PLUGIN && \ + sudo -u app git config core.filemode false && \ + sudo -u app git config pull.rebase false && \ + sudo -u app git pull origin master || echo warning: attempt to update plugin $PLUGIN failed. + fi + done +else + echo skipping local plugin updates, disabled. +fi + +PSQL="psql -q -h $TTRSS_DB_HOST -U $TTRSS_DB_USER $TTRSS_DB_NAME" + +$PSQL -c "create extension if not exists pg_trgm" + +RESTORE_SCHEMA=${SCRIPT_ROOT}/restore-schema.sql.gz + +if [ -r $RESTORE_SCHEMA ]; then + $PSQL -c "drop schema public cascade; create schema public;" + zcat $RESTORE_SCHEMA | $PSQL +fi + +# this was previously generated +rm -f $DST_DIR/config.php.bak + +if [ ! -z "${TTRSS_XDEBUG_ENABLED}" ]; then + if [ -z "${TTRSS_XDEBUG_HOST}" ]; then + export TTRSS_XDEBUG_HOST=$(ip ro sh 0/0 | cut -d " " -f 3) + fi + echo enabling xdebug with the following parameters: + env | grep TTRSS_XDEBUG + cat > /etc/php81/conf.d/50_xdebug.ini <<EOF +zend_extension=xdebug.so +xdebug.mode=develop,trace,debug +xdebug.start_with_request = yes +xdebug.client_port = ${TTRSS_XDEBUG_PORT} +xdebug.client_host = ${TTRSS_XDEBUG_HOST} +EOF +fi + +sed -i.bak "s/^\(memory_limit\) = \(.*\)/\1 = ${PHP_WORKER_MEMORY_LIMIT}/" \ + /etc/php81/php.ini + +sed -i.bak "s/^\(pm.max_children\) = \(.*\)/\1 = ${PHP_WORKER_MAX_CHILDREN}/" \ + /etc/php81/php-fpm.d/www.conf + +sudo -Eu app php81 $DST_DIR/update.php --update-schema=force-yes + +if [ ! -z "$ADMIN_USER_PASS" ]; then + sudo -Eu app php81 $DST_DIR/update.php --user-set-password "admin:$ADMIN_USER_PASS" +else + if sudo -Eu app php81 $DST_DIR/update.php --user-check-password "admin:password"; then + RANDOM_PASS=$(tr -dc A-Za-z0-9 </dev/urandom | head -c 16 ; echo '') + + echo "*****************************************************************************" + echo "* Setting initial built-in admin user password to '$RANDOM_PASS' *" + echo "* If you want to set it manually, use ADMIN_USER_PASS environment variable. *" + echo "*****************************************************************************" + + sudo -Eu app php81 $DST_DIR/update.php --user-set-password "admin:$RANDOM_PASS" + fi +fi + +if [ ! -z "$ADMIN_USER_ACCESS_LEVEL" ]; then + sudo -Eu app php81 $DST_DIR/update.php --user-set-access-level "admin:$ADMIN_USER_ACCESS_LEVEL" +fi + +if [ ! -z "$AUTO_CREATE_USER" ]; then + sudo -Eu app /bin/sh -c "php81 $DST_DIR/update.php --user-exists $AUTO_CREATE_USER || + php81 $DST_DIR/update.php --force-yes --user-add \"$AUTO_CREATE_USER:$AUTO_CREATE_USER_PASS:$AUTO_CREATE_USER_ACCESS_LEVEL\"" +fi + +rm -f /tmp/error.log && mkfifo /tmp/error.log && chown app:app /tmp/error.log + +(tail -q -f /tmp/error.log >> /proc/1/fd/2) & + +unset ADMIN_USER_PASS +unset AUTO_CREATE_USER_PASS + +touch $DST_DIR/.app_is_ready + +exec /usr/sbin/php-fpm81 --nodaemonize --force-stderr |