2018-03-15 15:55:12 +00:00
#!/bin/sh
set -eu
2016-07-30 14:30:52 +00:00
2017-04-17 20:49:53 +00:00
# version_greater A B returns whether A > B
2018-03-15 15:55:12 +00:00
version_greater( ) {
2018-08-01 21:19:53 +00:00
[ " $( printf '%s\n' " $@ " | sort -t '.' -n -k1,1 -k2,2 -k3,3 -k4,4 | head -n 1) " != " $1 " ]
2017-04-17 20:49:53 +00:00
}
Copy config, data, custom_apps, and themes to volume when empty
When Nextcloud performs an upgrade or clean installation,
it will check whether /var/www/html/{config,data,custom_apps,themes} exist.
If not, it will copy
/usr/src/nextcloud/{config,data,custom_apps,themes} to /var/www/html.
This leads to a problem: If those subdirectories are existent but
empty, it will not do the copy. This situation is common when you mount
volumes to those subdirectories, like:
```
version: "2.1"
services:
app:
image: nextcloud:12-apache
volumes:
- nextcloud:/var/www/html:Z
- nextcloud-custom_apps:/var/www/html/custom_apps:Z
- nextcloud-config:/var/www/html/config:Z
- nextcloud-data:/var/www/html/data:Z
- nextcloud-themes:/var/www/html/themes:Z
ports:
- 8080:80/tcp
db:
image: mariadb
volumes:
- db:/var/lib/mysql:Z
environment:
MYSQL_USER: nextcloud
MYSQL_DATABASE: nextcloud
MYSQL_PASSWORD: nextcloud
MYSQL_ROOT_PASSWORD: nextcloud
volumes:
nextcloud:
nextcloud-custom_apps:
nextcloud-config:
nextcloud-data:
nextcloud-themes:
db:
```
This patch will fix this issue by copying to those subdirectories when they
are empty.
2017-06-28 06:33:34 +00:00
# return true if specified directory is empty
2018-03-15 15:55:12 +00:00
directory_empty( ) {
[ -z " $( ls -A " $1 / " ) " ]
Copy config, data, custom_apps, and themes to volume when empty
When Nextcloud performs an upgrade or clean installation,
it will check whether /var/www/html/{config,data,custom_apps,themes} exist.
If not, it will copy
/usr/src/nextcloud/{config,data,custom_apps,themes} to /var/www/html.
This leads to a problem: If those subdirectories are existent but
empty, it will not do the copy. This situation is common when you mount
volumes to those subdirectories, like:
```
version: "2.1"
services:
app:
image: nextcloud:12-apache
volumes:
- nextcloud:/var/www/html:Z
- nextcloud-custom_apps:/var/www/html/custom_apps:Z
- nextcloud-config:/var/www/html/config:Z
- nextcloud-data:/var/www/html/data:Z
- nextcloud-themes:/var/www/html/themes:Z
ports:
- 8080:80/tcp
db:
image: mariadb
volumes:
- db:/var/lib/mysql:Z
environment:
MYSQL_USER: nextcloud
MYSQL_DATABASE: nextcloud
MYSQL_PASSWORD: nextcloud
MYSQL_ROOT_PASSWORD: nextcloud
volumes:
nextcloud:
nextcloud-custom_apps:
nextcloud-config:
nextcloud-data:
nextcloud-themes:
db:
```
This patch will fix this issue by copying to those subdirectories when they
are empty.
2017-06-28 06:33:34 +00:00
}
2018-03-15 15:55:12 +00:00
run_as( ) {
2018-08-01 21:19:53 +00:00
if [ " $( id -u) " = 0 ] ; then
2018-09-27 07:58:47 +00:00
su -p www-data -s /bin/sh -c " $1 "
2018-08-01 21:19:53 +00:00
else
sh -c " $1 "
fi
2017-07-17 19:35:16 +00:00
}
Copy config, data, custom_apps, and themes to volume when empty
When Nextcloud performs an upgrade or clean installation,
it will check whether /var/www/html/{config,data,custom_apps,themes} exist.
If not, it will copy
/usr/src/nextcloud/{config,data,custom_apps,themes} to /var/www/html.
This leads to a problem: If those subdirectories are existent but
empty, it will not do the copy. This situation is common when you mount
volumes to those subdirectories, like:
```
version: "2.1"
services:
app:
image: nextcloud:12-apache
volumes:
- nextcloud:/var/www/html:Z
- nextcloud-custom_apps:/var/www/html/custom_apps:Z
- nextcloud-config:/var/www/html/config:Z
- nextcloud-data:/var/www/html/data:Z
- nextcloud-themes:/var/www/html/themes:Z
ports:
- 8080:80/tcp
db:
image: mariadb
volumes:
- db:/var/lib/mysql:Z
environment:
MYSQL_USER: nextcloud
MYSQL_DATABASE: nextcloud
MYSQL_PASSWORD: nextcloud
MYSQL_ROOT_PASSWORD: nextcloud
volumes:
nextcloud:
nextcloud-custom_apps:
nextcloud-config:
nextcloud-data:
nextcloud-themes:
db:
```
This patch will fix this issue by copying to those subdirectories when they
are empty.
2017-06-28 06:33:34 +00:00
2018-10-13 20:19:16 +00:00
if expr " $1 " : "apache" 1>/dev/null || [ " $1 " = "php-fpm" ] || [ " ${ NEXTCLOUD_UPDATE :- 0 } " -eq 1 ] ; then
2019-04-26 13:49:59 +00:00
if [ -n " ${ REDIS_HOST +x } " ] ; then
echo "Configuring Redis as session handler"
{
echo 'session.save_handler = redis'
2020-01-10 23:38:38 +00:00
# check if redis host is an unix socket path
if [ " $( echo " $REDIS_HOST " | cut -c1-1) " = "/" ] ; then
if [ -n " ${ REDIS_HOST_PASSWORD +x } " ] ; then
echo " session.save_path = \"unix:// ${ REDIS_HOST } ?auth= ${ REDIS_HOST_PASSWORD } \" "
else
echo " session.save_path = \"unix:// ${ REDIS_HOST } \" "
fi
2019-09-10 00:31:16 +00:00
# check if redis password has been set
2020-01-10 23:38:38 +00:00
elif [ -n " ${ REDIS_HOST_PASSWORD +x } " ] ; then
2019-09-10 00:31:16 +00:00
echo " session.save_path = \"tcp:// ${ REDIS_HOST } : ${ REDIS_HOST_PORT : =6379 } ?auth= ${ REDIS_HOST_PASSWORD } \" "
else
echo " session.save_path = \"tcp:// ${ REDIS_HOST } : ${ REDIS_HOST_PORT : =6379 } \" "
fi
2019-04-26 13:49:59 +00:00
} > /usr/local/etc/php/conf.d/redis-session.ini
fi
2018-09-13 12:36:50 +00:00
installed_version = "0.0.0.0"
if [ -f /var/www/html/version.php ] ; then
# shellcheck disable=SC2016
installed_version = " $( php -r 'require "/var/www/html/version.php"; echo implode(".", $OC_Version);' ) "
fi
2018-03-15 15:55:12 +00:00
# shellcheck disable=SC2016
2018-09-13 12:36:50 +00:00
image_version = " $( php -r 'require "/usr/src/nextcloud/version.php"; echo implode(".", $OC_Version);' ) "
2017-04-17 20:49:53 +00:00
2018-09-13 12:36:50 +00:00
if version_greater " $installed_version " " $image_version " ; then
echo " Can't start Nextcloud because the version of the data ( $installed_version ) is higher than the docker image version ( $image_version ) and downgrading is not supported. Are you sure you have pulled the newest image version? "
exit 1
2017-04-17 21:00:56 +00:00
fi
2017-07-17 19:35:16 +00:00
2018-09-13 12:36:50 +00:00
if version_greater " $image_version " " $installed_version " ; then
2018-09-29 18:15:08 +00:00
echo " Initializing nextcloud $image_version ... "
2018-09-13 12:36:50 +00:00
if [ " $installed_version " != "0.0.0.0" ] ; then
2018-09-29 18:15:08 +00:00
echo " Upgrading nextcloud from $installed_version ... "
2018-09-13 12:36:50 +00:00
run_as 'php /var/www/html/occ app:list' | sed -n "/Enabled:/,/Disabled:/p" > /tmp/list_before
Copy config, data, custom_apps, and themes to volume when empty
When Nextcloud performs an upgrade or clean installation,
it will check whether /var/www/html/{config,data,custom_apps,themes} exist.
If not, it will copy
/usr/src/nextcloud/{config,data,custom_apps,themes} to /var/www/html.
This leads to a problem: If those subdirectories are existent but
empty, it will not do the copy. This situation is common when you mount
volumes to those subdirectories, like:
```
version: "2.1"
services:
app:
image: nextcloud:12-apache
volumes:
- nextcloud:/var/www/html:Z
- nextcloud-custom_apps:/var/www/html/custom_apps:Z
- nextcloud-config:/var/www/html/config:Z
- nextcloud-data:/var/www/html/data:Z
- nextcloud-themes:/var/www/html/themes:Z
ports:
- 8080:80/tcp
db:
image: mariadb
volumes:
- db:/var/lib/mysql:Z
environment:
MYSQL_USER: nextcloud
MYSQL_DATABASE: nextcloud
MYSQL_PASSWORD: nextcloud
MYSQL_ROOT_PASSWORD: nextcloud
volumes:
nextcloud:
nextcloud-custom_apps:
nextcloud-config:
nextcloud-data:
nextcloud-themes:
db:
```
This patch will fix this issue by copying to those subdirectories when they
are empty.
2017-06-28 06:33:34 +00:00
fi
2018-09-13 12:36:50 +00:00
if [ " $( id -u) " = 0 ] ; then
rsync_options = "-rlDog --chown www-data:root"
else
rsync_options = "-rlD"
fi
2018-10-01 13:28:13 +00:00
rsync $rsync_options --delete --exclude-from= /upgrade.exclude /usr/src/nextcloud/ /var/www/html/
2017-05-23 19:12:06 +00:00
2018-09-13 12:36:50 +00:00
for dir in config data custom_apps themes; do
if [ ! -d " /var/www/html/ $dir " ] || directory_empty " /var/www/html/ $dir " ; then
rsync $rsync_options --include " / $dir / " --exclude '/*' /usr/src/nextcloud/ /var/www/html/
2018-09-12 12:32:05 +00:00
fi
2018-09-13 12:36:50 +00:00
done
2019-02-26 22:46:57 +00:00
rsync $rsync_options --include '/version.php' --exclude '/*' /usr/src/nextcloud/ /var/www/html/
2018-09-29 18:15:08 +00:00
echo "Initializing finished"
2018-09-13 12:36:50 +00:00
#install
if [ " $installed_version " = "0.0.0.0" ] ; then
echo "New nextcloud instance"
2018-09-27 10:53:14 +00:00
2018-09-13 12:36:50 +00:00
if [ -n " ${ NEXTCLOUD_ADMIN_USER +x } " ] && [ -n " ${ NEXTCLOUD_ADMIN_PASSWORD +x } " ] ; then
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = '-n --admin-user "$NEXTCLOUD_ADMIN_USER" --admin-pass "$NEXTCLOUD_ADMIN_PASSWORD"'
2018-09-13 12:36:50 +00:00
if [ -n " ${ NEXTCLOUD_TABLE_PREFIX +x } " ] ; then
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = $install_options ' --database-table-prefix "$NEXTCLOUD_TABLE_PREFIX"'
2018-09-13 12:36:50 +00:00
fi
if [ -n " ${ NEXTCLOUD_DATA_DIR +x } " ] ; then
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = $install_options ' --data-dir "$NEXTCLOUD_DATA_DIR"'
2018-09-13 12:36:50 +00:00
fi
2018-09-27 10:53:14 +00:00
2018-10-02 08:45:00 +00:00
install = false
2019-06-22 16:22:15 +00:00
if [ -n " ${ SQLITE_DATABASE +x } " ] ; then
2018-09-13 12:36:50 +00:00
echo "Installing with SQLite database"
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = $install_options ' --database-name "$SQLITE_DATABASE"'
2018-10-02 08:45:00 +00:00
install = true
2018-09-13 12:36:50 +00:00
elif [ -n " ${ MYSQL_DATABASE +x } " ] && [ -n " ${ MYSQL_USER +x } " ] && [ -n " ${ MYSQL_PASSWORD +x } " ] && [ -n " ${ MYSQL_HOST +x } " ] ; then
echo "Installing with MySQL database"
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = $install_options ' --database mysql --database-name "$MYSQL_DATABASE" --database-user "$MYSQL_USER" --database-pass "$MYSQL_PASSWORD" --database-host "$MYSQL_HOST"'
2018-10-02 08:45:00 +00:00
install = true
2018-09-13 12:36:50 +00:00
elif [ -n " ${ POSTGRES_DB +x } " ] && [ -n " ${ POSTGRES_USER +x } " ] && [ -n " ${ POSTGRES_PASSWORD +x } " ] && [ -n " ${ POSTGRES_HOST +x } " ] ; then
echo "Installing with PostgreSQL database"
2018-09-27 10:53:14 +00:00
# shellcheck disable=SC2016
2018-09-27 07:58:47 +00:00
install_options = $install_options ' --database pgsql --database-name "$POSTGRES_DB" --database-user "$POSTGRES_USER" --database-pass "$POSTGRES_PASSWORD" --database-host "$POSTGRES_HOST"'
2018-10-02 08:45:00 +00:00
install = true
fi
2018-10-12 12:49:37 +00:00
2018-10-02 08:45:00 +00:00
if [ " $install " = true ] ; then
2018-12-12 18:21:48 +00:00
echo "starting nextcloud installation"
2018-10-02 08:45:00 +00:00
max_retries = 10
try = 0
until run_as " php /var/www/html/occ maintenance:install $install_options " || [ " $try " -gt " $max_retries " ]
do
echo "retrying install..."
try = $(( try+1))
2020-01-13 18:10:28 +00:00
sleep 10s
2018-10-02 08:45:00 +00:00
done
if [ " $try " -gt " $max_retries " ] ; then
echo "installing of nextcloud failed!"
exit 1
fi
2018-10-12 12:49:37 +00:00
if [ -n " ${ NEXTCLOUD_TRUSTED_DOMAINS +x } " ] ; then
echo "setting trusted domains…"
NC_TRUSTED_DOMAIN_IDX = 1
for DOMAIN in $NEXTCLOUD_TRUSTED_DOMAINS ; do
DOMAIN = $( echo " $DOMAIN " | sed -e 's/^[[:space:]]*//' -e 's/[[:space:]]*$//' )
run_as " php /var/www/html/occ config:system:set trusted_domains $NC_TRUSTED_DOMAIN_IDX --value= $DOMAIN "
NC_TRUSTED_DOMAIN_IDX = $(( $NC_TRUSTED_DOMAIN_IDX + 1 ))
done
fi
2018-09-13 12:36:50 +00:00
else
echo "running web-based installer on first connect!"
fi
2018-09-12 12:32:05 +00:00
fi
2018-09-13 12:36:50 +00:00
#upgrade
else
run_as 'php /var/www/html/occ upgrade'
2017-04-17 21:00:56 +00:00
2018-09-13 12:36:50 +00:00
run_as 'php /var/www/html/occ app:list' | sed -n "/Enabled:/,/Disabled:/p" > /tmp/list_after
echo "The following apps have been disabled:"
diff /tmp/list_before /tmp/list_after | grep '<' | cut -d- -f2 | cut -d: -f1
rm -f /tmp/list_before /tmp/list_after
2018-09-12 12:32:05 +00:00
2018-09-13 12:36:50 +00:00
fi
2017-04-17 20:57:48 +00:00
fi
2016-07-30 14:30:52 +00:00
fi
exec " $@ "