mirror of https://github.com/tteck/Proxmox.git
Compare commits
No commits in common. "9fb5e232bd56aa7a78a76e256b396390e2ebb135" and "c9a9e45be23e6f1b38f8878ee0651df683b98c12" have entirely different histories.
9fb5e232bd
...
c9a9e45be2
|
@ -96,5 +96,7 @@ build_container
|
||||||
description
|
description
|
||||||
|
|
||||||
msg_ok "Completed Successfully!\n"
|
msg_ok "Completed Successfully!\n"
|
||||||
echo -e "${APP} Setup should be reachable by going to the following URL.
|
echo -e "To retrieve the database credentials required for the Setup-Wizard, execute the same script within the LXC Console.\n
|
||||||
|
|
||||||
|
${APP} should be reachable by going to the following URL.
|
||||||
${BL}https://${IP}${CL} \n"
|
${BL}https://${IP}${CL} \n"
|
||||||
|
|
|
@ -52,7 +52,7 @@ function default_settings() {
|
||||||
|
|
||||||
function update_script() {
|
function update_script() {
|
||||||
header_info
|
header_info
|
||||||
if [[ ! -d /opt/rdtc/ ]]; then msg_error "No ${APP} Installation Found!"; exit; fi
|
if [[ ! -d /opt/rdtclient/ ]]; then msg_error "No ${APP} Installation Found!"; exit; fi
|
||||||
msg_info "Updating $APP LXC"
|
msg_info "Updating $APP LXC"
|
||||||
apt-get update &>/dev/null
|
apt-get update &>/dev/null
|
||||||
apt-get -y upgrade &>/dev/null
|
apt-get -y upgrade &>/dev/null
|
||||||
|
|
|
@ -23,30 +23,18 @@ $STD apk add mc
|
||||||
$STD apk add argon2
|
$STD apk add argon2
|
||||||
msg_ok "Installed Dependencies"
|
msg_ok "Installed Dependencies"
|
||||||
|
|
||||||
msg_info "Creating Credentials"
|
msg_info "Installing Alpine-Nextcloud"
|
||||||
DB_NAME=nextcloud
|
|
||||||
DB_USER=nextcloud
|
|
||||||
DB_PASS="$(openssl rand -base64 18 | cut -c1-13)"
|
|
||||||
ROOT_PASS="$(openssl rand -base64 18 | cut -c1-13)"
|
|
||||||
ADMIN_USER=ncAdmin
|
|
||||||
ADMIN_PASS="$(openssl rand -base64 18 | cut -c1-13)"
|
|
||||||
echo "" >>~/nextcloud.creds
|
|
||||||
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 -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
|
|
||||||
msg_ok "Created Credentials"
|
|
||||||
|
|
||||||
msg_info "Installing MySQL Database"
|
|
||||||
$STD apk add nextcloud-mysql mariadb mariadb-client
|
$STD apk add nextcloud-mysql mariadb mariadb-client
|
||||||
$STD mysql_install_db --user=mysql --datadir=/var/lib/mysql
|
$STD mysql_install_db --user=mysql --datadir=/var/lib/mysql
|
||||||
$STD service mariadb start
|
$STD service mariadb start
|
||||||
$STD rc-update add mariadb
|
$STD rc-update add mariadb
|
||||||
msg_ok "Installed MySQL Database"
|
msg_ok "Installed Alpine-Nextcloud"
|
||||||
|
|
||||||
msg_info "Setting up MySQL Database"
|
msg_info "Setting up MySQL database"
|
||||||
|
DB_NAME=nextcloud
|
||||||
|
DB_USER=nextcloud
|
||||||
|
DB_PASS="$(openssl rand -base64 18 | cut -c1-13)"
|
||||||
|
ROOT_PASS="$(openssl rand -base64 18 | cut -c1-13)"
|
||||||
$STD mysql -uroot -e "GRANT ALL PRIVILEGES ON *.* TO 'root'@'localhost' IDENTIFIED BY '$ROOT_PASS' WITH GRANT OPTION;FLUSH PRIVILEGES;"
|
$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='';"
|
||||||
$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 "DELETE FROM mysql.user WHERE User='root' AND Host NOT IN ('localhost', '127.0.0.1', '::1');"
|
||||||
|
@ -56,8 +44,13 @@ $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' 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 "GRANT ALL ON $DB_NAME.* TO '$DB_USER'@'localhost.localdomain' IDENTIFIED BY '$DB_PASS';"
|
||||||
$STD mysql -uroot -p$ROOT_PASS -e "FLUSH PRIVILEGES;"
|
$STD mysql -uroot -p$ROOT_PASS -e "FLUSH PRIVILEGES;"
|
||||||
|
echo "" >>~/nextcloud.creds
|
||||||
|
echo -e "MySQL Root Password: \e[32m$ROOT_PASS\e[0m" >>~/nextcloud.creds
|
||||||
|
echo -e "Nextcloud Database User: \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
|
||||||
$STD apk del mariadb-client
|
$STD apk del mariadb-client
|
||||||
msg_ok "Set up MySQL Database"
|
msg_ok "Set up MySQL database"
|
||||||
|
|
||||||
msg_info "Installing Web-Server"
|
msg_info "Installing Web-Server"
|
||||||
$STD apk add nextcloud-initscript
|
$STD apk add nextcloud-initscript
|
||||||
|
@ -70,7 +63,7 @@ msg_ok "Installed Web-Server"
|
||||||
|
|
||||||
msg_info "Setting up 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"
|
$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"
|
||||||
rm /etc/nginx/http.d/default.conf
|
$STD rm /etc/nginx/http.d/default.conf
|
||||||
cat <<'EOF' >/etc/nginx/http.d/nextcloud.conf
|
cat <<'EOF' >/etc/nginx/http.d/nextcloud.conf
|
||||||
server {
|
server {
|
||||||
listen [::]:80;
|
listen [::]:80;
|
||||||
|
@ -136,23 +129,33 @@ $STD apk add nextcloud-activity
|
||||||
$STD apk add nextcloud-admin_audit
|
$STD apk add nextcloud-admin_audit
|
||||||
$STD apk add nextcloud-comments
|
$STD apk add nextcloud-comments
|
||||||
$STD apk add nextcloud-dashboard
|
$STD apk add nextcloud-dashboard
|
||||||
|
$STD apk add nextcloud-default-apps
|
||||||
$STD apk add nextcloud-doc
|
$STD apk add nextcloud-doc
|
||||||
$STD apk add nextcloud-encryption
|
$STD apk add nextcloud-encryption
|
||||||
$STD apk add nextcloud-federation
|
$STD apk add nextcloud-federation
|
||||||
$STD apk add nextcloud-files_external
|
$STD apk add nextcloud-files_external
|
||||||
|
$STD apk add nextcloud-files_pdfviewer
|
||||||
|
$STD apk add nextcloud-files_rightclick
|
||||||
$STD apk add nextcloud-files_sharing
|
$STD apk add nextcloud-files_sharing
|
||||||
$STD apk add nextcloud-files_trashbin
|
$STD apk add nextcloud-files_trashbin
|
||||||
$STD apk add nextcloud-files_versions
|
$STD apk add nextcloud-files_versions
|
||||||
|
$STD apk add nextcloud-logreader
|
||||||
$STD apk add nextcloud-notifications
|
$STD apk add nextcloud-notifications
|
||||||
|
$STD apk add nextcloud-password_policy
|
||||||
|
$STD apk add nextcloud-photos
|
||||||
|
$STD apk add nextcloud-privacy
|
||||||
|
$STD apk add nextcloud-recommendations
|
||||||
|
$STD apk add nextcloud-serverinfo
|
||||||
$STD apk add nextcloud-sharebymail
|
$STD apk add nextcloud-sharebymail
|
||||||
$STD apk add nextcloud-suspicious_login
|
$STD apk add nextcloud-suspicious_login
|
||||||
$STD apk add nextcloud-support
|
$STD apk add nextcloud-support
|
||||||
$STD apk add nextcloud-systemtags
|
$STD apk add nextcloud-systemtags
|
||||||
|
$STD apk add nextcloud-text
|
||||||
$STD apk add nextcloud-user_status
|
$STD apk add nextcloud-user_status
|
||||||
$STD apk add nextcloud-weather_status
|
$STD apk add nextcloud-weather_status
|
||||||
msg_ok "Added Additional Nextcloud Packages"
|
msg_ok "Added Additional Nextcloud Packages"
|
||||||
|
|
||||||
msg_info "Setting up PHP/Redis"
|
msg_info "Setting up PHP-opcache + Redis"
|
||||||
$STD apk add php82-opcache
|
$STD apk add php82-opcache
|
||||||
$STD apk add php82-redis
|
$STD apk add php82-redis
|
||||||
$STD apk add php82-apcu
|
$STD apk add php82-apcu
|
||||||
|
@ -166,7 +169,7 @@ sed -i -e 's|;opcache.save_comments=1|opcache.save_comments=1|' /etc/php82/php.i
|
||||||
sed -i -e 's|;opcache.revalidate_freq=1|opcache.revalidate_freq=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-update add redis
|
||||||
$STD rc-service redis start
|
$STD rc-service redis start
|
||||||
msg_ok "Set up PHP/Redis"
|
msg_ok "Set up PHP-opcache + Redis"
|
||||||
|
|
||||||
msg_info "Setting up Nextcloud-Cronjob"
|
msg_info "Setting up Nextcloud-Cronjob"
|
||||||
mkdir -p /etc/periodic/5min
|
mkdir -p /etc/periodic/5min
|
||||||
|
@ -178,8 +181,7 @@ 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'
|
su nextcloud -s /bin/sh -c 'php82 -f /usr/share/webapps/nextcloud/cron.php'
|
||||||
fi
|
fi
|
||||||
EOF
|
EOF
|
||||||
(crontab -l ; echo "*/5 * * * * run-parts /etc/periodic/5min") | crontab -
|
sed -i '/monthly/a */5 * * * * run-parts /etc/periodic/5min' /etc/crontabs/root
|
||||||
chmod +x /etc/periodic/5min/nextcloud_cron
|
|
||||||
msg_ok "Set up Nextcloud-Cronjob"
|
msg_ok "Set up Nextcloud-Cronjob"
|
||||||
|
|
||||||
msg_info "Setting up Nextcloud-Config"
|
msg_info "Setting up Nextcloud-Config"
|
||||||
|
@ -220,6 +222,7 @@ $CONFIG = array (
|
||||||
'dbindex' => 0,
|
'dbindex' => 0,
|
||||||
'timeout' => 1.5,
|
'timeout' => 1.5,
|
||||||
),
|
),
|
||||||
|
|
||||||
'installed' => false,
|
'installed' => false,
|
||||||
);
|
);
|
||||||
EOF
|
EOF
|
||||||
|
@ -227,7 +230,7 @@ msg_ok "Set up Nextcloud-Config"
|
||||||
|
|
||||||
msg_info "Starting Alpine-Nextcloud"
|
msg_info "Starting Alpine-Nextcloud"
|
||||||
$STD rc-service php-fpm82 start
|
$STD rc-service php-fpm82 start
|
||||||
chown -R nextcloud:www-data /var/log/nextcloud/
|
$STD chown -R nextcloud:www-data /var/log/nextcloud/
|
||||||
$STD rc-service php-fpm82 restart
|
$STD rc-service php-fpm82 restart
|
||||||
$STD rc-service nginx start
|
$STD rc-service nginx start
|
||||||
$STD rc-service nextcloud start
|
$STD rc-service nextcloud start
|
||||||
|
@ -235,17 +238,5 @@ $STD rc-update add nginx default
|
||||||
$STD rc-update add nextcloud default
|
$STD rc-update add nextcloud default
|
||||||
msg_ok "Started Alpine-Nextcloud"
|
msg_ok "Started Alpine-Nextcloud"
|
||||||
|
|
||||||
msg_info "Start Setup-Wizard"
|
|
||||||
cd /usr/share/webapps/nextcloud
|
|
||||||
$STD su nextcloud -s /bin/sh -c "php82 occ maintenance:install \
|
|
||||||
--database='mysql' --database-name $DB_NAME \
|
|
||||||
--database-user '$DB_USER' --database-pass '$DB_PASS' \
|
|
||||||
--admin-user '$ADMIN_USER' --admin-pass '$ADMIN_PASS' \
|
|
||||||
--data-dir '/var/lib/nextcloud/data'"
|
|
||||||
$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"
|
|
||||||
|
|
||||||
motd_ssh
|
motd_ssh
|
||||||
customize
|
customize
|
||||||
|
|
Loading…
Reference in New Issue