nextcloud.sh 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. #!/usr/bin/env bash
  2. for bin in curl dirmngr; do
  3. if [[ -z $(which ${bin}) ]]; then echo "Cannot find ${bin}, exiting..."; exit 1; fi
  4. done
  5. [[ -z ${1} ]] && NC_HELP=y
  6. while [ "$1" != '' ]; do
  7. case "${1}" in
  8. -p|--purge) NC_PURGE=y && shift;;
  9. -i|--install) NC_INSTALL=y && shift;;
  10. -h|--help) NC_HELP=y && shift;;
  11. *) echo "Unknown parameter: ${1}" && shift;;
  12. esac
  13. done
  14. if [[ ${NC_HELP} == "y" ]]; then
  15. printf 'Usage:\n\n'
  16. printf ' -p|--purge\n Purge Nextcloud\n'
  17. printf ' -i|--install\n Install Nextcloud\n\n'
  18. exit 0
  19. fi
  20. [[ ${NC_PURGE} == "y" ]] && [[ ${NC_INSTALL} == "y" ]] && { echo "Cannot use -p and -i at the same time"; }
  21. SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
  22. cd ${SCRIPT_DIR}/../
  23. source mailcow.conf
  24. if [[ ${NC_PURGE} == "y" ]]; then
  25. read -r -p "Are you sure you want to purge Nextcloud? [y/N] " response
  26. response=${response,,}
  27. if [[ ! "$response" =~ ^(yes|y)$ ]]; then
  28. echo "OK, aborting."
  29. exit 1
  30. fi
  31. docker exec -it $(docker ps -f name=mysql-mailcow -q) mysql -uroot -p${DBROOT} -e \
  32. "$(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)"
  33. docker exec -it $(docker ps -f name=redis-mailcow -q) /bin/sh -c ' cat <<EOF | redis-cli
  34. SELECT 10
  35. FLUSHDB
  36. EOF
  37. '
  38. if [ -d ./data/web/nextcloud/config ]; then
  39. mv ./data/web/nextcloud/config/ ./data/conf/nextcloud-config-folder-$(date +%s).bak
  40. fi
  41. [[ -d ./data/web/nextcloud ]] && rm -rf ./data/web/nextcloud
  42. [[ -f ./data/conf/nginx/site.nextcloud.custom ]] && mv ./data/conf/nginx/site.nextcloud.custom ./data/conf/nginx/site.nextcloud.custom-$(date +%s).bak
  43. [[ -f ./data/conf/nginx/nextcloud.conf ]] && mv ./data/conf/nginx/nextcloud.conf ./data/conf/nginx/nextcloud.conf-$(date +%s).bak
  44. docker restart $(docker ps -aqf name=nginx-mailcow)
  45. elif [[ ${NC_UPDATE} == "y" ]]; then
  46. exit;
  47. read -r -p "Are you sure you want to update Nextcloud? [y/N] " response
  48. response=${response,,}
  49. if [[ ! "$response" =~ ^(yes|y)$ ]]; then
  50. echo "OK, aborting."
  51. exit 1
  52. fi
  53. if [ ! -f data/web/nextcloud/occ ]; then
  54. echo "Nextcloud occ not found. Is Nextcloud installed?"
  55. exit 1
  56. fi
  57. 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
  58. echo "Nextcloud seems not to be installed."
  59. exit 1
  60. elif ! grep -q 'version: 15\.' <<<$(docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings status"); then
  61. echo "Cannot upgrade to new major version, please update manually."
  62. exit 1
  63. else
  64. curl -L# -o nextcloud.tar.bz2 "https://download.nextcloud.com/server/releases/latest-15.tar.bz2" || { echo "Failed to download Nextcloud archive."; exit 1; } \
  65. && tar -xjf nextcloud.tar.bz2 -C ./data/web/ \
  66. && rm nextcloud.tar.bz2 \
  67. && mkdir -p ./data/web/nextcloud/data \
  68. && chmod +x ./data/web/nextcloud/occ \
  69. docker exec -it $(docker ps -f name=php-fpm-mailcow -q) bash -c "chown www-data:www-data -R /web/nextcloud" \
  70. docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) bash -c "/web/nextcloud/occ --no-warnings upgrade"
  71. fi
  72. elif [[ ${NC_INSTALL} == "y" ]]; then
  73. NC_SUBD=
  74. while [[ -z ${NC_SUBD} ]]; do
  75. read -p "Subdomain to run Nextcloud from [format: nextcloud.domain.tld]: " NC_SUBD
  76. done
  77. if ! ping -q -c2 ${NC_SUBD} > /dev/null 2>&1 ; then
  78. read -p "Cannot ping subdomain, continue anyway? [y|N] " NC_CONT_FAIL
  79. [[ ! ${NC_CONT_FAIL,,} =~ ^(yes|y)$ ]] && { echo "Ok, exiting..."; exit 1; }
  80. fi
  81. ADMIN_NC_PASS=$(</dev/urandom tr -dc A-Za-z0-9 | head -c 28)
  82. curl -L# -o nextcloud.tar.bz2 "https://download.nextcloud.com/server/releases/latest-15.tar.bz2" || { echo "Failed to download Nextcloud archive."; exit 1; } \
  83. && tar -xjf nextcloud.tar.bz2 -C ./data/web/ \
  84. && rm nextcloud.tar.bz2 \
  85. && mkdir -p ./data/web/nextcloud/data \
  86. && chmod +x ./data/web/nextcloud/occ
  87. docker exec -it $(docker ps -f name=php-fpm-mailcow -q) /bin/bash -c "chown -R www-data:www-data /web/nextcloud"
  88. docker exec -it -u www-data $(docker ps -f name=php-fpm-mailcow -q) /web/nextcloud/occ --no-warnings maintenance:install \
  89. --database mysql \
  90. --database-host mysql \
  91. --database-name ${DBNAME} \
  92. --database-user ${DBUSER} \
  93. --database-pass ${DBPASS} \
  94. --database-table-prefix nc_ \
  95. --admin-user admin \
  96. --admin-pass ${ADMIN_NC_PASS} \
  97. --data-dir /web/nextcloud/data
  98. 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; \
  99. /web/nextcloud/occ --no-warnings config:system:set redis port --value=6379 --type=integer; \
  100. /web/nextcloud/occ --no-warnings config:system:set redis timeout --value=0.0 --type=integer; \
  101. /web/nextcloud/occ --no-warnings config:system:set redis dbindex --value=10 --type=integer; \
  102. /web/nextcloud/occ --no-warnings config:system:set memcache.locking --value='\OC\Memcache\Redis' --type=string; \
  103. /web/nextcloud/occ --no-warnings config:system:set memcache.local --value='\OC\Memcache\Redis' --type=string; \
  104. /web/nextcloud/occ --no-warnings config:system:set trusted_domains 1 --value=${MAILCOW_HOSTNAME}; \
  105. /web/nextcloud/occ --no-warnings config:system:set trusted_proxies 0 --value=${IPV6_NETWORK}; \
  106. /web/nextcloud/occ --no-warnings config:system:set trusted_proxies 1 --value=${IPV4_NETWORK}.0/24; \
  107. /web/nextcloud/occ --no-warnings config:system:set overwritewebroot --value=/nextcloud; \
  108. /web/nextcloud/occ --no-warnings config:system:set overwritehost --value=${MAILCOW_HOSTNAME}; \
  109. /web/nextcloud/occ --no-warnings config:system:set overwriteprotocol --value=https; \
  110. /web/nextcloud/occ --no-warnings config:system:set mail_smtpmode --value=smtp; \
  111. /web/nextcloud/occ --no-warnings config:system:set mail_smtpauthtype --value=LOGIN; \
  112. /web/nextcloud/occ --no-warnings config:system:set mail_from_address --value=nextcloud; \
  113. /web/nextcloud/occ --no-warnings config:system:set mail_domain --value=${MAILCOW_HOSTNAME}; \
  114. /web/nextcloud/occ --no-warnings config:system:set mail_smtphost --value=postfix; \
  115. /web/nextcloud/occ --no-warnings config:system:set mail_smtpport --value=588; \
  116. /web/nextcloud/occ --no-warnings config:system:set trusted_domains 1 --value=${NC_SUBD}; \
  117. /web/nextcloud/occ --no-warnings config:system:set overwritewebroot --value=/; \
  118. /web/nextcloud/occ --no-warnings config:system:set overwritehost --value=${NC_SUBD}; \
  119. /web/nextcloud/occ --no-warnings db:convert-filecache-bigint -n"
  120. # Not installing by default, broke too often
  121. #/web/nextcloud/occ --no-warnings app:install user_external; \
  122. #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 arguments 0 --value={dovecot:143/imap/tls/novalidate-cert}; \
  123. #/web/nextcloud/occ --no-warnings config:system:set user_backends 0 class --value=OC_User_IMAP; \
  124. cp ./data/assets/nextcloud/nextcloud.conf ./data/conf/nginx/
  125. sed -i "s/NC_SUBD/${NC_SUBD}/g" ./data/conf/nginx/nextcloud.conf
  126. echo "Restarting Nginx..."
  127. docker restart $(docker ps -aqf name=nginx-mailcow)
  128. echo "Login as admin with password: ${ADMIN_NC_PASS}"
  129. fi