[Nextcloud] Updated and improved script (implemented -u and more)
This commit is contained in:
		| @@ -9,9 +9,14 @@ done | |||||||
| [[ -z ${1} ]] && NC_HELP=y | [[ -z ${1} ]] && NC_HELP=y | ||||||
|  |  | ||||||
| while [ "$1" != '' ]; do | while [ "$1" != '' ]; do | ||||||
|  |   if [[ $# -ne 1 ]]; then | ||||||
|  |       echo -e "\033[31mPlease use only one parameter at the same time!\033[0m" >&2 | ||||||
|  |       exit 2 | ||||||
|  |   fi | ||||||
|   case "${1}" in |   case "${1}" in | ||||||
|     -p|--purge) NC_PURGE=y && shift;; |     -p|--purge) NC_PURGE=y && shift;; | ||||||
|     -i|--install) NC_INSTALL=y && shift;; |     -i|--install) NC_INSTALL=y && shift;; | ||||||
|  |     -u|--update)  NC_UPDATE=y && shift;; | ||||||
|     -r|--resetpw) NC_RESETPW=y && shift;; |     -r|--resetpw) NC_RESETPW=y && shift;; | ||||||
|     -h|--help) NC_HELP=y && shift;; |     -h|--help) NC_HELP=y && shift;; | ||||||
|     *) echo "Unknown parameter: ${1}" && shift;; |     *) echo "Unknown parameter: ${1}" && shift;; | ||||||
| @@ -22,13 +27,11 @@ if [[ ${NC_HELP} == "y" ]]; then | |||||||
|   printf 'Usage:\n\n' |   printf 'Usage:\n\n' | ||||||
|   printf '  -p|--purge\n    Purge Nextcloud\n' |   printf '  -p|--purge\n    Purge Nextcloud\n' | ||||||
|   printf '  -i|--install\n    Install Nextcloud\n' |   printf '  -i|--install\n    Install Nextcloud\n' | ||||||
|  |   printf '  -u|--update\n    Update Nextcloud\n' | ||||||
|   printf '  -r|--resetpw\n    Reset password\n\n' |   printf '  -r|--resetpw\n    Reset password\n\n' | ||||||
|   exit 0 |   exit 0 | ||||||
| fi | fi | ||||||
|  |  | ||||||
| [[ ${NC_PURGE} == "y" ]] && [[ ${NC_INSTALL} == "y" ]] && { echo "Cannot use -p and -i at the same time!"; exit 1; } |  | ||||||
| [[ ${NC_PURGE} == "y" ]] && [[ ${NC_RESETPW} == "y" ]] && { echo "Cannot use -p and -r at the same time!"; exit 1; } |  | ||||||
|  |  | ||||||
| SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" | ||||||
| cd ${SCRIPT_DIR}/../ | cd ${SCRIPT_DIR}/../ | ||||||
| source mailcow.conf | source mailcow.conf | ||||||
| @@ -41,8 +44,27 @@ if [[ ${NC_PURGE} == "y" ]]; then | |||||||
|     exit 1 |     exit 1 | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e \ |   echo -e "\033[33mDetecting Database information...\033[0m" | ||||||
|     "$(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "SELECT IFNULL(GROUP_CONCAT('DROP TABLE ', TABLE_SCHEMA, '.', TABLE_NAME SEPARATOR ';'),'SELECT NULL;') FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE 'oc_%' AND TABLE_SCHEMA = '${DBNAME}';" -BN)" |   if [[ $(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "Show databases" | grep "nextcloud") ]]; then | ||||||
|  |     echo -e "\033[32mFound seperate nextcloud Database (newer scheme)!\033[0m" | ||||||
|  |     echo -e "\033[31mPurging...\033[0m" | ||||||
|  |     docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "DROP DATABASE nextcloud;" > /dev/null | ||||||
|  |     docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "DROP USER 'nextcloud'@'%';" > /dev/null | ||||||
|  |   elif [[ $(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} mailcow -e "SHOW TABLES LIKE 'oc_%'") && $? -eq 0 ]]; then | ||||||
|  |     echo -e "\033[32mFound nextcloud (oc) tables inside of mailcow Database (old scheme)!\033[0m" | ||||||
|  |     echo -e "\033[31mPurging...\033[0m" | ||||||
|  |     docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e \ | ||||||
|  |      "$(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "SELECT IFNULL(GROUP_CONCAT('DROP TABLE ', TABLE_SCHEMA, '.', TABLE_NAME SEPARATOR ';'),'SELECT NULL;') FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE 'oc_%' AND TABLE_SCHEMA = '${DBNAME}';" -BN)" > /dev/null | ||||||
|  |   elif [[ $(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} mailcow -e "SHOW TABLES LIKE 'nc_%'") && $? -eq 0 ]]; then | ||||||
|  |     echo -e "\033[32mFound nextcloud (nc) tables inside of mailcow Database (old scheme)!\033[0m" | ||||||
|  |     echo -e "\033[31mPurging...\033[0m" | ||||||
|  |     docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e \ | ||||||
|  |      "$(docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "SELECT IFNULL(GROUP_CONCAT('DROP TABLE ', TABLE_SCHEMA, '.', TABLE_NAME SEPARATOR ';'),'SELECT NULL;') FROM INFORMATION_SCHEMA.TABLES WHERE TABLE_NAME LIKE 'nc_%' AND TABLE_SCHEMA = '${DBNAME}';" -BN)" > /dev/null | ||||||
|  |   else | ||||||
|  |     echo -e "\033[31mError: No Nextcloud Databases/Tables found!" | ||||||
|  |     echo -e "\033[33mNot purging anything...\033[0m" | ||||||
|  |     exit 1 | ||||||
|  |   fi | ||||||
|   docker exec -it $(docker ps -f name=redis-mailcow -q) /bin/sh -c ' cat <<EOF | redis-cli |   docker exec -it $(docker ps -f name=redis-mailcow -q) /bin/sh -c ' cat <<EOF | redis-cli | ||||||
| SELECT 10 | SELECT 10 | ||||||
| FLUSHDB | FLUSHDB | ||||||
| @@ -58,9 +80,10 @@ EOF | |||||||
|  |  | ||||||
|   docker restart $(docker ps -aqf name=nginx-mailcow) |   docker restart $(docker ps -aqf name=nginx-mailcow) | ||||||
|  |  | ||||||
|  |   echo -e "\033[32mNextcloud has been sucessfully uninstalled!\033[0m" | ||||||
|  |  | ||||||
| elif [[ ${NC_UPDATE} == "y" ]]; then | elif [[ ${NC_UPDATE} == "y" ]]; then | ||||||
|   exit; |   read -r -p "Are you sure you want to update Nextcloud (with nextclouds own updater)? [y/N] " response | ||||||
|   read -r -p "Are you sure you want to update Nextcloud? [y/N] " response |  | ||||||
|   response=${response,,} |   response=${response,,} | ||||||
|   if [[ ! "$response" =~ ^(yes|y)$ ]]; then |   if [[ ! "$response" =~ ^(yes|y)$ ]]; then | ||||||
|     echo "OK, aborting." |     echo "OK, aborting." | ||||||
| @@ -68,23 +91,14 @@ elif [[ ${NC_UPDATE} == "y" ]]; then | |||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   if [ ! -f data/web/nextcloud/occ ]; then |   if [ ! -f data/web/nextcloud/occ ]; then | ||||||
|     echo "Nextcloud occ not found. Is Nextcloud installed?" |     echo -e "\033[31mError: Nextcloud occ not found. Is Nextcloud installed?\033[0m" | ||||||
|     exit 1 |     exit 1 | ||||||
|   fi |   fi | ||||||
|   if ! grep -q 'installed: true' <<<$(docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings status"); then |   if ! grep -q 'installed: true' <<<$(docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings status"); then | ||||||
|     echo "Nextcloud seems not to be installed." |     echo "Nextcloud seems not to be installed." | ||||||
|     exit 1 |     exit 1 | ||||||
|   elif ! grep -q 'version: 20\.' <<<$(docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings status"); then |  | ||||||
|     echo "Cannot upgrade to new major version, please update manually." |  | ||||||
|     exit 1 |  | ||||||
|   else |   else | ||||||
|     curl -L# -o nextcloud.tar.bz2 "https://download.nextcloud.com/server/releases/nextcloud-$NEXTCLOUD_VERSION.tar.bz2" || { echo "Failed to download Nextcloud archive."; exit 1; } \ |     docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "php /web/nextcloud/updater/updater.phar" | ||||||
|       && tar -xjf nextcloud.tar.bz2 -C ./data/web/ \ |  | ||||||
|       && rm nextcloud.tar.bz2 \ |  | ||||||
|       && mkdir -p ./data/web/nextcloud/data \ |  | ||||||
|       && chmod +x ./data/web/nextcloud/occ \ |  | ||||||
|        docker exec -it $(docker ps -f name=php-fpm-mailcow -q) bash -c "chown www-data:www-data -R /web/nextcloud" \ |  | ||||||
|        docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings upgrade" |  | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
| elif [[ ${NC_INSTALL} == "y" ]]; then | elif [[ ${NC_INSTALL} == "y" ]]; then | ||||||
| @@ -97,25 +111,48 @@ elif [[ ${NC_INSTALL} == "y" ]]; then | |||||||
|     [[ ! ${NC_CONT_FAIL,,} =~ ^(yes|y)$ ]] && { echo "Ok, exiting..."; exit 1; } |     [[ ! ${NC_CONT_FAIL,,} =~ ^(yes|y)$ ]] && { echo "Ok, exiting..."; exit 1; } | ||||||
|   fi |   fi | ||||||
|  |  | ||||||
|   ADMIN_NC_PASS=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28) |   echo -e "\033[33mDownloading \033[34mNextcloud ${NEXTCLOUD_VERSION}\033[33m...\033[0m" | ||||||
|  |  | ||||||
|   curl -L# -o nextcloud.tar.bz2 "https://download.nextcloud.com/server/releases/nextcloud-$NEXTCLOUD_VERSION.tar.bz2" || { echo "Failed to download Nextcloud archive."; exit 1; } \ |   curl -L# -o nextcloud.tar.bz2 "https://download.nextcloud.com/server/releases/nextcloud-$NEXTCLOUD_VERSION.tar.bz2" || { echo "Failed to download Nextcloud archive."; exit 1; } \ | ||||||
|     && tar -xjf nextcloud.tar.bz2 -C ./data/web/ \ |     && tar -xjf nextcloud.tar.bz2 -C ./data/web/ \ | ||||||
|     && rm nextcloud.tar.bz2 \ |     && rm nextcloud.tar.bz2 \ | ||||||
|     && mkdir -p ./data/web/nextcloud/data \ |     && mkdir -p ./data/web/nextcloud/data \ | ||||||
|     && chmod +x ./data/web/nextcloud/occ |     && chmod +x ./data/web/nextcloud/occ | ||||||
|  |  | ||||||
|  |   echo -e "\033[33mCreating Nextcloud Database...\033[0m" | ||||||
|  |   NC_DBPASS=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28) | ||||||
|  |   NC_DBUSER=nextcloud | ||||||
|  |   NC_DBNAME=nextcloud | ||||||
|  |  | ||||||
|  |   echo -ne "[1/3] Creating nextcloud Database" | ||||||
|  |   docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "CREATE DATABASE ${NC_DBNAME};" | ||||||
|  |   sleep 2 | ||||||
|  |   echo -ne "\r[2/3] Creating nextcloud Database user" | ||||||
|  |   docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "CREATE USER '${NC_DBUSER}'@'%' IDENTIFIED BY '${NC_DBPASS}';" | ||||||
|  |   sleep 2 | ||||||
|  |   echo -ne "\r[3/3] Granting nextcloud user all permissions on database nextcloud" | ||||||
|  |   docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e "GRANT ALL PRIVILEGES ON ${NC_DBNAME}.* TO '${NC_DBUSER}'@'%';" | ||||||
|  |   sleep 2 | ||||||
|  |  | ||||||
|  |   echo "" | ||||||
|  |   echo -e "\033[33mInstalling Nextcloud...\033[0m" | ||||||
|  |   ADMIN_NC_PASS=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28) | ||||||
|  |  | ||||||
|  |   echo -ne "[1/4] Setting correct permissions for www-data" | ||||||
|   docker exec -it $(docker ps -f name=php-fpm-mailcow -q) /bin/bash -c "chown -R www-data:www-data /web/nextcloud" |   docker exec -it $(docker ps -f name=php-fpm-mailcow -q) /bin/bash -c "chown -R www-data:www-data /web/nextcloud" | ||||||
|  |   sleep 2 | ||||||
|  |   echo -ne "\r[2/4] Running occ maintenance:install to install nextcloud" | ||||||
|   docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) /web/nextcloud/occ --no-warnings maintenance:install \ |   docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) /web/nextcloud/occ --no-warnings maintenance:install \ | ||||||
|     --database mysql \ |     --database mysql \ | ||||||
|     --database-host mysql \ |     --database-host mysql \ | ||||||
|     --database-name ${DBNAME} \ |     --database-name ${NC_DBNAME} \ | ||||||
|     --database-user ${DBUSER} \ |     --database-user ${NC_DBUSER} \ | ||||||
|     --database-pass ${DBPASS} \ |     --database-pass ${NC_DBPASS} \ | ||||||
|     --admin-user admin \ |     --admin-user admin \ | ||||||
|     --admin-pass ${ADMIN_NC_PASS} \ |     --admin-pass ${ADMIN_NC_PASS} \ | ||||||
|       --data-dir /web/nextcloud/data |       --data-dir /web/nextcloud/data 2>&1 /dev/null | ||||||
|  |  | ||||||
|  |   echo -ne "\r[3/4] Setting custom parameters inside the nextcloud config file" | ||||||
|  |   echo "" | ||||||
|   docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings config:system:set redis host --value=redis --type=string; \ |   docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings config:system:set redis host --value=redis --type=string; \ | ||||||
|     /web/nextcloud/occ --no-warnings config:system:set redis port --value=6379 --type=integer; \ |     /web/nextcloud/occ --no-warnings config:system:set redis port --value=6379 --type=integer; \ | ||||||
|     /web/nextcloud/occ --no-warnings config:system:set redis timeout --value=0.0 --type=integer; \ |     /web/nextcloud/occ --no-warnings config:system:set redis timeout --value=0.0 --type=integer; \ | ||||||
| @@ -141,13 +178,28 @@ elif [[ ${NC_INSTALL} == "y" ]]; then | |||||||
|     #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 arguments 0 --value={dovecot:143/imap/tls/novalidate-cert}; \ |     #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 arguments 0 --value={dovecot:143/imap/tls/novalidate-cert}; \ | ||||||
|     #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 class --value=OC_User_IMAP; \ |     #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 class --value=OC_User_IMAP; \ | ||||||
|  |  | ||||||
|  |     echo -e "\r[4/4] Enabling NGINX Configuration" | ||||||
|     cp ./data/assets/nextcloud/nextcloud.conf ./data/conf/nginx/ |     cp ./data/assets/nextcloud/nextcloud.conf ./data/conf/nginx/ | ||||||
|     sed -i "s/NC_SUBD/${NC_SUBD}/g" ./data/conf/nginx/nextcloud.conf |     sed -i "s/NC_SUBD/${NC_SUBD}/g" ./data/conf/nginx/nextcloud.conf | ||||||
|  |     sleep 2 | ||||||
|  |  | ||||||
|   echo "Restarting Nginx..." |   echo "" | ||||||
|  |   echo -e "\033[33mFinalizing installation...\033[0m" | ||||||
|   docker restart $(docker ps -aqf name=nginx-mailcow) |   docker restart $(docker ps -aqf name=nginx-mailcow) | ||||||
|  |  | ||||||
|   echo "Login as admin with password: ${ADMIN_NC_PASS}" |   echo "" | ||||||
|  |   echo "******************************************" | ||||||
|  |   echo "*        SAVE THESE CREDENTIALS          *" | ||||||
|  |   echo "*    INSTALL DATE: $(date +%Y-%m-%d_%H-%M-%S)   *" | ||||||
|  |   echo "******************************************" | ||||||
|  |   echo "" | ||||||
|  |   echo -e "\033[36mDatabase Name:      ${NC_DBNAME}\033[0m" | ||||||
|  |   echo -e "\033[36mDatabase User:      ${NC_DBUSER}\033[0m" | ||||||
|  |   echo -e "\033[36mDatabase Password:  ${NC_DBPASS}\033[0m" | ||||||
|  |   echo "" | ||||||
|  |   echo -e "\033[31mUI Admin Password:  ${ADMIN_NC_PASS}\033[0m" | ||||||
|  |   echo "" | ||||||
|  |  | ||||||
|  |  | ||||||
| elif [[ ${NC_RESETPW} == "y" ]]; then | elif [[ ${NC_RESETPW} == "y" ]]; then | ||||||
|     printf 'You are about to set a new password for a Nextcloud user.\n\nDo not use this option if your Nextcloud is configured to use mailcow for authentication.\nSet a new password for the corresponding mailbox in mailcow, instead.\n\n' |     printf 'You are about to set a new password for a Nextcloud user.\n\nDo not use this option if your Nextcloud is configured to use mailcow for authentication.\nSet a new password for the corresponding mailbox in mailcow, instead.\n\n' | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user