From 6faf005189dd1504394451b593fbe724f8ebba2c Mon Sep 17 00:00:00 2001 From: tteckster Date: Fri, 29 Sep 2023 12:34:23 -0400 Subject: [PATCH] Update alpine-nextcloud-install.sh code refactoring --- install/alpine-nextcloud-install.sh | 185 +++++++++++++--------------- 1 file changed, 83 insertions(+), 102 deletions(-) diff --git a/install/alpine-nextcloud-install.sh b/install/alpine-nextcloud-install.sh index 39cc825f..ae30ab31 100644 --- a/install/alpine-nextcloud-install.sh +++ b/install/alpine-nextcloud-install.sh @@ -20,9 +20,30 @@ $STD apk add openssl $STD apk add openssh $STD apk add nano $STD apk add mc -$STD apk add argon2 +$STD apk add nginx +echo -e "export VISUAL=nano\nexport EDITOR=nano" >>/etc/profile msg_ok "Installed Dependencies" +msg_info "Installing PHP/Redis" +$STD apk add php82-opcache +$STD apk add php82-redis +$STD apk add php82-apcu +$STD apk add php82-fpm +$STD apk add php82-sysvsem +$STD apk add php82-pecl-imagick +$STD apk add php82-exif +$STD apk add redis +sed -i -e 's|;opcache.enable=1|opcache.enable=1|' /etc/php82/php.ini +sed -i -e 's|;opcache.enable_cli=1|opcache.enable_cli=1|' /etc/php82/php.ini +sed -i -e 's|;opcache.interned_strings_buffer=8|opcache.interned_strings_buffer=16|' /etc/php82/php.ini +sed -i -e 's|;opcache.max_accelerated_files=10000|opcache.max_accelerated_files=10000|' /etc/php82/php.ini +sed -i -e 's|;opcache.memory_consumption=128|opcache.memory_consumption=256|' /etc/php82/php.ini +sed -i -e 's|;opcache.save_comments=1|opcache.save_comments=1|' /etc/php82/php.ini +sed -i -e 's|;opcache.revalidate_freq=1|opcache.revalidate_freq=1|' /etc/php82/php.ini +$STD rc-update add redis +$STD rc-service redis start +msg_ok "Installed PHP/Redis" + msg_info "Creating Credentials" DB_NAME=nextcloud DB_USER=nextcloud @@ -35,8 +56,9 @@ echo -e "MySQL Admin Password: \e[32m$ROOT_PASS\e[0m" >>~/nextcloud.creds echo -e "Nextcloud Database Username: \e[32m$DB_USER\e[0m" >>~/nextcloud.creds echo -e "Nextcloud Database Password: \e[32m$DB_PASS\e[0m" >>~/nextcloud.creds echo -e "Nextcloud Database Name: \e[32m$DB_NAME\e[0m" >>~/nextcloud.creds +echo "" >>~/nextcloud.creds echo -e "Nextcloud Admin Username: \e[32m$ADMIN_USER\e[0m" >>~/nextcloud.creds -echo -e "Nextcloud Admin Password: \e[32m$ADMIN_PASS\e[0m" >>~/nextcloud.creds +echo -e "Nextcloud Admin Password: \e[32m$ADMIN_PASS\e[0m (Initially enter twice)" >>~/nextcloud.creds msg_ok "Created Credentials" msg_info "Installing MySQL Database" @@ -44,32 +66,62 @@ $STD apk add nextcloud-mysql mariadb mariadb-client $STD mysql_install_db --user=mysql --datadir=/var/lib/mysql $STD service mariadb start $STD rc-update add mariadb + +mysql -uroot -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY '$ROOT_PASS' WITH GRANT OPTION;FLUSH PRIVILEGES;" +mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.user WHERE User='';" +mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1');" +mysql -uroot -p$ROOT_PASS -e "DROP DATABASE test;" +mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.db WHERE Db='test' OR Db='test\_%';" +mysql -uroot -p$ROOT_PASS -e "CREATE DATABASE $DB_NAME;" +mysql -uroot -p$ROOT_PASS -e "GRANT ALL ON $DB_NAME.* TO '$DB_USER'@'localhost' IDENTIFIED BY '$DB_PASS';" +mysql -uroot -p$ROOT_PASS -e "GRANT ALL ON $DB_NAME.* TO '$DB_USER'@'localhost.localdomain' IDENTIFIED BY '$DB_PASS';" +mysql -uroot -p$ROOT_PASS -e "FLUSH PRIVILEGES;" +$STD apk del mariadb-client msg_ok "Installed MySQL Database" -msg_info "Setting up MySQL Database" -$STD mysql -uroot -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY '$ROOT_PASS' WITH GRANT OPTION;FLUSH PRIVILEGES;" -$STD mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.user WHERE User='';" -$STD mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1');" -$STD mysql -uroot -p$ROOT_PASS -e "DROP DATABASE test;" -$STD mysql -uroot -p$ROOT_PASS -e "DELETE FROM mysql.db WHERE Db='test' OR Db='test\_%';" -$STD mysql -uroot -p$ROOT_PASS -e "CREATE DATABASE $DB_NAME;" -$STD mysql -uroot -p$ROOT_PASS -e "GRANT ALL ON $DB_NAME.* TO '$DB_USER'@'localhost' IDENTIFIED BY '$DB_PASS';" -$STD mysql -uroot -p$ROOT_PASS -e "GRANT ALL ON $DB_NAME.* TO '$DB_USER'@'localhost.localdomain' IDENTIFIED BY '$DB_PASS';" -$STD mysql -uroot -p$ROOT_PASS -e "FLUSH PRIVILEGES;" -$STD apk del mariadb-client -msg_ok "Set up MySQL Database" - -msg_info "Installing Web-Server" +msg_info "Installing Nextcloud" $STD apk add nextcloud-initscript -$STD apk add nginx -$STD apk add php82-fpm -$STD apk add php82-sysvsem -$STD apk add php82-pecl-imagick -$STD apk add php82-exif -msg_ok "Installed Web-Server" - -msg_info "Setting up Web-Server" $STD openssl req -x509 -nodes -days 365 -newkey rsa:4096 -keyout /etc/ssl/private/nextcloud-selfsigned.key -out /etc/ssl/certs/nextcloud-selfsigned.crt -subj "/C=US/O=Nextcloud/OU=Domain Control Validated/CN=nextcloud.local" +cat <<'EOF' >/usr/share/webapps/nextcloud/config/config.php + '/var/lib/nextcloud/data', + 'logfile' => '/var/log/nextcloud/nextcloud.log', + 'logdateformat' => 'F d, Y H:i:s', + 'log_rotate_size' => 104857600, + 'apps_paths' => array ( + // Read-only location for apps shipped with Nextcloud and installed by apk. + 0 => array ( + 'path' => '/usr/share/webapps/nextcloud/apps', + 'url' => '/apps', + 'writable' => false, + ), + // Writable location for apps installed from AppStore. + 1 => array ( + 'path' => '/var/lib/nextcloud/apps', + 'url' => '/apps-appstore', + 'writable' => true, + ), + ), + 'updatechecker' => false, + 'check_for_working_htaccess' => false, + + // Uncomment to enable Zend OPcache. + 'memcache.local' => '\\OC\\Memcache\\Redis', + + // Uncomment this and add user nextcloud to the redis group to enable Redis + // cache for file locking. This is highly recommended, see + // https://github.com/nextcloud/server/issues/9305. + 'memcache.locking' => '\\OC\\Memcache\\Redis', + 'redis' => array( + 'host' => 'localhost', + 'port' => 6379, + 'dbindex' => 0, + 'timeout' => 1.5, + ), + 'installed' => false, +); +EOF rm /etc/nginx/http.d/default.conf cat <<'EOF' >/etc/nginx/http.d/nextcloud.conf server { @@ -129,9 +181,10 @@ sed -i -e 's|php_admin_value\[post_max_size\] = 513M|php_admin_value\[post_max_s sed -i -e 's|php_admin_value\[upload_max_filesize\] = 513M|php_admin_value\[upload_max_filesize\] = 5121M|' /etc/php82/php-fpm.d/nextcloud.conf sed -i -e 's|upload_max_filesize = 513M|upload_max_filesize = 5121M|' /etc/php82/php.ini sed -i -e 's|memory_limit = 128M|memory_limit = 512M|' /etc/php82/php.ini -msg_ok "Set up Web-Server" +msg_ok "Installed Nextcloud" msg_info "Adding Additional Nextcloud Packages" +$STD apk add nextcloud-default-apps $STD apk add nextcloud-activity $STD apk add nextcloud-admin_audit $STD apk add nextcloud-comments @@ -152,80 +205,7 @@ $STD apk add nextcloud-user_status $STD apk add nextcloud-weather_status msg_ok "Added Additional Nextcloud Packages" -msg_info "Setting up PHP/Redis" -$STD apk add php82-opcache -$STD apk add php82-redis -$STD apk add php82-apcu -$STD apk add redis -sed -i -e 's|;opcache.enable=1|opcache.enable=1|' /etc/php82/php.ini -sed -i -e 's|;opcache.enable_cli=1|opcache.enable_cli=1|' /etc/php82/php.ini -sed -i -e 's|;opcache.interned_strings_buffer=8|opcache.interned_strings_buffer=16|' /etc/php82/php.ini -sed -i -e 's|;opcache.max_accelerated_files=10000|opcache.max_accelerated_files=10000|' /etc/php82/php.ini -sed -i -e 's|;opcache.memory_consumption=128|opcache.memory_consumption=256|' /etc/php82/php.ini -sed -i -e 's|;opcache.save_comments=1|opcache.save_comments=1|' /etc/php82/php.ini -sed -i -e 's|;opcache.revalidate_freq=1|opcache.revalidate_freq=1|' /etc/php82/php.ini -$STD rc-update add redis -$STD rc-service redis start -msg_ok "Set up PHP/Redis" - -msg_info "Setting up Nextcloud-Cronjob" -mkdir -p /etc/periodic/5min -cat <<'EOF' >/etc/periodic/5min/nextcloud_cron -#!/bin/sh - -# Run only when nextcloud service is started. -if rc-service nextcloud -q status >/dev/null 2>&1; then - su nextcloud -s /bin/sh -c 'php82 -f /usr/share/webapps/nextcloud/cron.php' -fi -EOF -(crontab -l ; echo "*/5 * * * * run-parts /etc/periodic/5min") | crontab - -chmod +x /etc/periodic/5min/nextcloud_cron -msg_ok "Set up Nextcloud-Cronjob" - -msg_info "Setting up Nextcloud-Config" -cat <<'EOF' >/usr/share/webapps/nextcloud/config/config.php - '/var/lib/nextcloud/data', - 'logfile' => '/var/log/nextcloud/nextcloud.log', - 'logdateformat' => 'F d, Y H:i:s', - 'log_rotate_size' => 104857600, - 'apps_paths' => array ( - // Read-only location for apps shipped with Nextcloud and installed by apk. - 0 => array ( - 'path' => '/usr/share/webapps/nextcloud/apps', - 'url' => '/apps', - 'writable' => false, - ), - // Writable location for apps installed from AppStore. - 1 => array ( - 'path' => '/var/lib/nextcloud/apps', - 'url' => '/apps-appstore', - 'writable' => true, - ), - ), - 'updatechecker' => false, - 'check_for_working_htaccess' => false, - - // Uncomment to enable Zend OPcache. - 'memcache.local' => '\\OC\\Memcache\\Redis', - - // Uncomment this and add user nextcloud to the redis group to enable Redis - // cache for file locking. This is highly recommended, see - // https://github.com/nextcloud/server/issues/9305. - 'memcache.locking' => '\\OC\\Memcache\\Redis', - 'redis' => array( - 'host' => 'localhost', - 'port' => 6379, - 'dbindex' => 0, - 'timeout' => 1.5, - ), - 'installed' => false, -); -EOF -msg_ok "Set up Nextcloud-Config" - -msg_info "Starting Alpine-Nextcloud" +msg_info "Starting Services" $STD rc-service php-fpm82 start chown -R nextcloud:www-data /var/log/nextcloud/ $STD rc-service php-fpm82 restart @@ -233,9 +213,9 @@ $STD rc-service nginx start $STD rc-service nextcloud start $STD rc-update add nginx default $STD rc-update add nextcloud default -msg_ok "Started Alpine-Nextcloud" +msg_ok "Started Services" -msg_info "Start Setup-Wizard" +msg_info "Start Nextcloud Setup-Wizard" cd /usr/share/webapps/nextcloud $STD su nextcloud -s /bin/sh -c "php82 occ maintenance:install \ --database='mysql' --database-name $DB_NAME \ @@ -245,7 +225,8 @@ $STD su nextcloud -s /bin/sh -c "php82 occ maintenance:install \ $STD su nextcloud -s /bin/sh -c 'php82 occ background:cron' IP4=$(/sbin/ip -o -4 addr list eth0 | awk '{print $4}' | cut -d/ -f1) sed -i "/0 => \'localhost\',/a \ \1 => '$IP4'," /usr/share/webapps/nextcloud/config/config.php -msg_ok "Finished Setup-Wizard" +su nextcloud -s /bin/sh -c 'php82 -f /usr/share/webapps/nextcloud/cron.php' +msg_ok "Finished Nextcloud Setup-Wizard" motd_ssh customize