forked from switnet/quick-jibri-installer
				
			Compare commits
	
		
			5 Commits
		
	
	
		
			a943997ea9
			...
			b8b15b4e9c
		
	
	| Author | SHA1 | Date | 
|---|---|---|
|  | b8b15b4e9c | |
|  | aec2d9898c | |
|  | f557e3cc2f | |
|  | a7a9768b6f | |
|  | cda665246e | 
|  | @ -0,0 +1,177 @@ | ||||||
|  | # Nextcloud 28 nginx - configuration | ||||||
|  | upstream php-handler { | ||||||
|  |     #server 127.0.0.1:9000; | ||||||
|  |     server unix:/run/php/php_PHPVER-fpm.sock; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | # Set the `immutable` cache control options only for assets with a cache busting `v` argument | ||||||
|  | map $arg_v $asset_immutable { | ||||||
|  |     "" ""; | ||||||
|  |     default "immutable"; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | server { | ||||||
|  |     listen 80; | ||||||
|  |     listen [::]:80; | ||||||
|  |     server_name _NC_DOMAIN; | ||||||
|  |     # enforce https | ||||||
|  |     return 301 https://\$server_name\$request_uri; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | server { | ||||||
|  |     listen _NC_NGINX_SSL_PORT ssl http2; | ||||||
|  |     listen [::]:_NC_NGINX_SSL_PORT ssl http2; | ||||||
|  |     server_name _NC_DOMAIN; | ||||||
|  | 
 | ||||||
|  |     # Path to the root of your installation | ||||||
|  |     root _NC_PATH/; | ||||||
|  | 
 | ||||||
|  |     ssl_certificate /etc/letsencrypt/live/_NC_DOMAIN/fullchain.pem; | ||||||
|  |     ssl_certificate_key /etc/letsencrypt/live/_NC_DOMAIN/privkey.pem; | ||||||
|  | 
 | ||||||
|  |     # Prevent nginx HTTP Server Detection | ||||||
|  |     server_tokens off; | ||||||
|  | 
 | ||||||
|  |     # HSTS settings | ||||||
|  |     # WARNING: Only add the preload option once you read about | ||||||
|  |     # the consequences in https://hstspreload.org/. This option | ||||||
|  |     # will add the domain to a hardcoded list that is shipped | ||||||
|  |     # in all major browsers and getting removed from this list | ||||||
|  |     # could take several months. | ||||||
|  |     #add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload" always; | ||||||
|  | 
 | ||||||
|  |     # set max upload size and increase upload timeout: | ||||||
|  |     client_max_body_size 512M; | ||||||
|  |     client_body_timeout 300s; | ||||||
|  |     fastcgi_buffers 64 4K; | ||||||
|  | 
 | ||||||
|  |     # Enable gzip but do not remove ETag headers | ||||||
|  |     gzip on; | ||||||
|  |     gzip_vary on; | ||||||
|  |     gzip_comp_level 4; | ||||||
|  |     gzip_min_length 256; | ||||||
|  |     gzip_proxied expired no-cache no-store private no_last_modified no_etag auth; | ||||||
|  |     gzip_types application/atom+xml text/javascript application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/wasm application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy; | ||||||
|  | 
 | ||||||
|  |     # Pagespeed is not supported by Nextcloud, so if your server is built | ||||||
|  |     # with the `ngx_pagespeed` module, uncomment this line to disable it. | ||||||
|  |     #pagespeed off; | ||||||
|  | 
 | ||||||
|  |     # The settings allows you to optimize the HTTP2 bandwidth. | ||||||
|  |     # See https://blog.cloudflare.com/delivering-http-2-upload-speed-improvements/ | ||||||
|  |     # for tuning hints | ||||||
|  |     client_body_buffer_size 512k; | ||||||
|  | 
 | ||||||
|  |     # HTTP response headers borrowed from Nextcloud `.htaccess` | ||||||
|  |     add_header Referrer-Policy                   "no-referrer"       always; | ||||||
|  |     add_header X-Content-Type-Options            "nosniff"           always; | ||||||
|  |     add_header X-Frame-Options                   "SAMEORIGIN"        always; | ||||||
|  |     add_header X-Permitted-Cross-Domain-Policies "none"              always; | ||||||
|  |     add_header X-Robots-Tag                      "noindex, nofollow" always; | ||||||
|  |     add_header X-XSS-Protection                  "1; mode=block"     always; | ||||||
|  | 
 | ||||||
|  |     # Remove X-Powered-By, which is an information leak | ||||||
|  |     fastcgi_hide_header X-Powered-By; | ||||||
|  | 
 | ||||||
|  |     # Specify how to handle directories -- specifying `/index.php$request_uri` | ||||||
|  |     # here as the fallback means that Nginx always exhibits the desired behaviour | ||||||
|  |     # when a client requests a path that corresponds to a directory that exists | ||||||
|  |     # on the server. In particular, if that directory contains an index.php file, | ||||||
|  |     # that file is correctly served; if it doesn't, then the request is passed to | ||||||
|  |     # the front-end controller. This consistent behaviour means that we don't need | ||||||
|  |     # to specify custom rules for certain paths (e.g. images and other assets, | ||||||
|  |     # `/updater`, `/ocs-provider`), and thus | ||||||
|  |     # `try_files $uri $uri/ /index.php$request_uri` | ||||||
|  |     # always provides the desired behaviour. | ||||||
|  |     index index.php index.html /index.php$request_uri; | ||||||
|  | 
 | ||||||
|  |     # Rule borrowed from `.htaccess` to handle Microsoft DAV clients | ||||||
|  |     location = / { | ||||||
|  |         if ( $http_user_agent ~ ^DavClnt ) { | ||||||
|  |             return 302 /remote.php/webdav/$is_args$args; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     location = /robots.txt { | ||||||
|  |         allow all; | ||||||
|  |         log_not_found off; | ||||||
|  |         access_log off; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     # Make a regex exception for `/.well-known` so that clients can still | ||||||
|  |     # access it despite the existence of the regex rule | ||||||
|  |     # `location ~ /(\.|autotest|...)` which would otherwise handle requests | ||||||
|  |     # for `/.well-known`. | ||||||
|  |     location ^~ /.well-known { | ||||||
|  |         # The rules in this block are an adaptation of the rules | ||||||
|  |         # in `.htaccess` that concern `/.well-known`. | ||||||
|  | 
 | ||||||
|  |         location = /.well-known/carddav { return 301 /remote.php/dav/; } | ||||||
|  |         location = /.well-known/caldav  { return 301 /remote.php/dav/; } | ||||||
|  | 
 | ||||||
|  |         location /.well-known/acme-challenge    { try_files $uri $uri/ =404; } | ||||||
|  |         location /.well-known/pki-validation    { try_files $uri $uri/ =404; } | ||||||
|  | 
 | ||||||
|  |         # Let Nextcloud's API for `/.well-known` URIs handle all other | ||||||
|  |         # requests by passing them to the front-end controller. | ||||||
|  |         return 301 /index.php$request_uri; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     # Rules borrowed from `.htaccess` to hide certain paths from clients | ||||||
|  |     location ~ ^/(?:build|tests|config|lib|3rdparty|templates|data)(?:$|/)  { return 404; } | ||||||
|  |     location ~ ^/(?:\.|autotest|occ|issue|indie|db_|console)                { return 404; } | ||||||
|  | 
 | ||||||
|  |     # Ensure this block, which passes PHP files to the PHP process, is above the blocks | ||||||
|  |     # which handle static assets (as seen below). If this block is not declared first, | ||||||
|  |     # then Nginx will encounter an infinite rewriting loop when it prepends `/index.php` | ||||||
|  |     # to the URI, resulting in a HTTP 500 error response. | ||||||
|  |     location ~ \.php(?:$|/) { | ||||||
|  |         # Required for legacy support | ||||||
|  |         rewrite ^/(?!index|remote|public|cron|core\/ajax\/update|status|ocs\/v[12]|updater\/.+|ocs-provider\/.+|.+\/richdocumentscode\/proxy) /index.php$request_uri; | ||||||
|  | 
 | ||||||
|  |         fastcgi_split_path_info ^(.+?\.php)(/.*)$; | ||||||
|  |         set $path_info $fastcgi_path_info; | ||||||
|  | 
 | ||||||
|  |         try_files $fastcgi_script_name =404; | ||||||
|  | 
 | ||||||
|  |         include fastcgi_params; | ||||||
|  |         fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; | ||||||
|  |         fastcgi_param PATH_INFO $path_info; | ||||||
|  |         fastcgi_param HTTPS on; | ||||||
|  | 
 | ||||||
|  |         fastcgi_param modHeadersAvailable true;         # Avoid sending the security headers twice | ||||||
|  |         fastcgi_param front_controller_active true;     # Enable pretty urls | ||||||
|  |         fastcgi_pass php-handler; | ||||||
|  | 
 | ||||||
|  |         fastcgi_intercept_errors on; | ||||||
|  |         fastcgi_request_buffering off; | ||||||
|  | 
 | ||||||
|  |         fastcgi_max_temp_file_size 0; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     # Serve static files | ||||||
|  |     location ~ \.(?:css|js|mjs|svg|gif|png|jpg|ico|wasm|tflite|map|ogg|flac)$ { | ||||||
|  |         try_files $uri /index.php$request_uri; | ||||||
|  |         add_header Cache-Control "public, max-age=15778463, $asset_immutable"; | ||||||
|  |         access_log off;     # Optional: Don't log access to assets | ||||||
|  | 
 | ||||||
|  |         location ~ \.wasm$ { | ||||||
|  |             default_type application/wasm; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     location ~ \.woff2?$ { | ||||||
|  |         try_files $uri /index.php$request_uri; | ||||||
|  |         expires 7d;         # Cache-Control policy borrowed from `.htaccess` | ||||||
|  |         access_log off;     # Optional: Don't log access to assets | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     # Rule borrowed from `.htaccess` | ||||||
|  |     location /remote { | ||||||
|  |         return 301 /remote.php$request_uri; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     location / { | ||||||
|  |         try_files $uri $uri/ /index.php$request_uri; | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | @ -42,7 +42,9 @@ apt_repo="/etc/apt/sources.list.d" | ||||||
| ENABLE_BLESSM="TBD" | ENABLE_BLESSM="TBD" | ||||||
| G_CHROME=$(apt-cache madison google-chrome-stable|awk '{print$3}'|cut -d. -f1-3) | G_CHROME=$(apt-cache madison google-chrome-stable|awk '{print$3}'|cut -d. -f1-3) | ||||||
| CHROMELAB_URL="https://googlechromelabs.github.io/chrome-for-testing" | CHROMELAB_URL="https://googlechromelabs.github.io/chrome-for-testing" | ||||||
| CHD_LTST_DWNL=$(curl -s $CHROMELAB_URL/known-good-versions-with-downloads.json | jq -r ".versions[].downloads.chromedriver | select(. != null) | .[].url" | grep linux64 | grep "$G_CHROME" | tail -1) | CHD_LTST_DWNL=$(curl -s $CHROMELAB_URL/known-good-versions-with-downloads.json | \ | ||||||
|  |                 jq -r ".versions[].downloads.chromedriver | select(. != null) | .[].url" | \ | ||||||
|  |                 grep linux64 | grep "$G_CHROME" | tail -1) | ||||||
| CHD_LTST=$(awk -F '/' '{print$7}' <<< "$CHD_LTST_DWNL") | CHD_LTST=$(awk -F '/' '{print$7}' <<< "$CHD_LTST_DWNL") | ||||||
| CHD_LTST_2D="$(cut -d "." -f 1,2 <<<  "$CHD_LTST")" | CHD_LTST_2D="$(cut -d "." -f 1,2 <<<  "$CHD_LTST")" | ||||||
| CHDB="$(whereis chromedriver | awk '{print$2}')" | CHDB="$(whereis chromedriver | awk '{print$2}')" | ||||||
|  | @ -123,6 +125,7 @@ update_nodejs_repo() { | ||||||
|         -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0" |         -o Dir::Etc::sourceparts="-" -o APT::Get::List-Cleanup="0" | ||||||
|     apt-get install -q2 --only-upgrade <<< printf "${nodejs_package[@]}" |     apt-get install -q2 --only-upgrade <<< printf "${nodejs_package[@]}" | ||||||
| } | } | ||||||
|  | check_latest_gc() { | ||||||
| printwc "${Purple}" "Checking for Google Chrome\n" | printwc "${Purple}" "Checking for Google Chrome\n" | ||||||
| if [ -f /usr/bin/google-chrome ]; then | if [ -f /usr/bin/google-chrome ]; then | ||||||
|     GOOGL_VER_2D="$(/usr/bin/google-chrome --version|awk '{printf "%.1f\n", $NF}')" |     GOOGL_VER_2D="$(/usr/bin/google-chrome --version|awk '{printf "%.1f\n", $NF}')" | ||||||
|  | @ -130,8 +133,11 @@ else | ||||||
|     printwc "${Yellow}" " -> Seems there is no Google Chrome installed\n" |     printwc "${Yellow}" " -> Seems there is no Google Chrome installed\n" | ||||||
|     IS_GLG_CHRM="no" |     IS_GLG_CHRM="no" | ||||||
| fi | fi | ||||||
|  | } | ||||||
|  | check_latest_gc | ||||||
| upgrade_cd() { | upgrade_cd() { | ||||||
| if [ -n "$GOOGL_VER_2D" ]; then | if [ -n "$GOOGL_VER_2D" ]; then | ||||||
|  |     check_latest_gc | ||||||
|     if version_gt "$GOOGL_VER_2D" "$CHD_VER_2D" ; then |     if version_gt "$GOOGL_VER_2D" "$CHD_VER_2D" ; then | ||||||
|         echo "Upgrading Chromedriver to Google Chromes version" |         echo "Upgrading Chromedriver to Google Chromes version" | ||||||
|         wget -q "$CHD_LTST_DWNL" \ |         wget -q "$CHD_LTST_DWNL" \ | ||||||
|  | @ -259,6 +265,10 @@ printwc "${Purple}" "========== Enable $NC_DOMAIN for sync client ==========\n" | ||||||
|         echo "$NC_DOMAIN seems to be on place, skipping..." |         echo "$NC_DOMAIN seems to be on place, skipping..." | ||||||
|     fi |     fi | ||||||
| fi | fi | ||||||
|  | 
 | ||||||
|  | # Final check & upgrade call. | ||||||
|  | check_lst_cd | ||||||
|  | 
 | ||||||
| if [ "$JIBRI_NODE" = "yes" ]; then | if [ "$JIBRI_NODE" = "yes" ]; then | ||||||
|     restart_jibri |     restart_jibri | ||||||
| else | else | ||||||
|  |  | ||||||
							
								
								
									
										308
									
								
								jra_nextcloud.sh
								
								
								
								
							
							
						
						
									
										308
									
								
								jra_nextcloud.sh
								
								
								
								
							|  | @ -14,7 +14,7 @@ done | ||||||
| 
 | 
 | ||||||
| #DEBUG | #DEBUG | ||||||
| if [ "$MODE" = "debug" ]; then | if [ "$MODE" = "debug" ]; then | ||||||
| set -x |     set -x | ||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| if ! [ "$(id -u)" = 0 ]; then | if ! [ "$(id -u)" = 0 ]; then | ||||||
|  | @ -42,14 +42,9 @@ apt-get update -q2 | ||||||
| # Manually add prerequisites. | # Manually add prerequisites. | ||||||
| apt-get install -y curl letsencrypt nginx | apt-get install -y curl letsencrypt nginx | ||||||
| 
 | 
 | ||||||
| DISTRO_RELEASE="$(lsb_release -sc)" | MIN_PHP="8.2" | ||||||
| DOMAIN="$(find /etc/prosody/conf.d/ -name \*.lua|awk -F'.cfg' '!/localhost/{print $1}'|xargs basename)" | DOMAIN="$(find /etc/prosody/conf.d/ -name \*.lua|awk -F'.cfg' '!/localhost/{print $1}'|xargs basename)" | ||||||
| PHP_REPO="$(apt-cache policy | awk '/http/&&/php/{print$2}' | awk -F "/" 'NR==1{print$5}')" |  | ||||||
| PHPVER="$(apt-cache madison php|grep -v ppa|awk -F'[:+]' 'NR==1{print $2}')" |  | ||||||
| PSGVER="$(apt-cache madison postgresql|tr -d '[:blank:]'|awk -F'[|+]' 'NR==1{print $2}')" | PSGVER="$(apt-cache madison postgresql|tr -d '[:blank:]'|awk -F'[|+]' 'NR==1{print $2}')" | ||||||
| PHP_FPM_DIR="/etc/php/$PHPVER/fpm" |  | ||||||
| PHP_INI="$PHP_FPM_DIR/php.ini" |  | ||||||
| PHP_CONF="/etc/php/$PHPVER/fpm/pool.d/www.conf" |  | ||||||
| NC_NGINX_SSL_PORT="$(grep "listen 44" /etc/nginx/sites-available/"$DOMAIN".conf | awk '{print$2}')" | NC_NGINX_SSL_PORT="$(grep "listen 44" /etc/nginx/sites-available/"$DOMAIN".conf | awk '{print$2}')" | ||||||
| [ -z "$NC_NGINX_SSL_PORT" ] && NC_NGINX_SSL_PORT="443" | [ -z "$NC_NGINX_SSL_PORT" ] && NC_NGINX_SSL_PORT="443" | ||||||
| NC_REPO="https://download.nextcloud.com/server/releases" | NC_REPO="https://download.nextcloud.com/server/releases" | ||||||
|  | @ -67,28 +62,8 @@ JITSI_MEET_PROXY="/etc/nginx/modules-enabled/60-jitsi-meet.conf" | ||||||
| PUBLIC_IP="$(dig +short myip.opendns.com @resolver1.opendns.com)" | PUBLIC_IP="$(dig +short myip.opendns.com @resolver1.opendns.com)" | ||||||
| ISO3166_CODE=TBD | ISO3166_CODE=TBD | ||||||
| NL="$(printf '\n  ')" | NL="$(printf '\n  ')" | ||||||
| TMP_GPG_REPO="$(mktemp -d)" |  | ||||||
| 
 | 
 | ||||||
| add_gpg_keyring() { | 
 | ||||||
| apt-key adv --recv-keys --keyserver keyserver.ubuntu.com "$1" |  | ||||||
| apt-key export "$1" | gpg --dearmour | tee "$TMP_GPG_REPO"/"$1".gpg >/dev/null |  | ||||||
| apt-key del "$1" |  | ||||||
| mv "$TMP_GPG_REPO"/"$1".gpg /etc/apt/trusted.gpg.d/ |  | ||||||
| } |  | ||||||
| install_aval_package() { |  | ||||||
| for i in $1 |  | ||||||
|   do |  | ||||||
|      if [ -z "$(apt-cache madison "$i" 2>/dev/null)" ]; then |  | ||||||
|      echo " > Package $i not available on repo." |  | ||||||
|      else |  | ||||||
|      echo " > Add package $i to the install list" |  | ||||||
|      packages="$packages $i" |  | ||||||
|      fi |  | ||||||
|  done |  | ||||||
|  echo "$packages" |  | ||||||
|  apt-get -y install $packages |  | ||||||
|  packages="" |  | ||||||
| } |  | ||||||
| exit_ifinstalled() { | exit_ifinstalled() { | ||||||
| if [ "$(dpkg-query -W -f='${Status}' "$1" 2>/dev/null | grep -c "ok installed")" == "1" ]; then | if [ "$(dpkg-query -W -f='${Status}' "$1" 2>/dev/null | grep -c "ok installed")" == "1" ]; then | ||||||
|     echo " This instance already has $1 installed, exiting..." |     echo " This instance already has $1 installed, exiting..." | ||||||
|  | @ -105,18 +80,6 @@ else | ||||||
|     apt-get -yq2 install "$1" |     apt-get -yq2 install "$1" | ||||||
| fi | fi | ||||||
| } | } | ||||||
| add_php() { |  | ||||||
| if [ "$PHP_REPO" = "php" ]; then |  | ||||||
|     echo "PHP $PHPVER already installed" |  | ||||||
|     apt-get -q2 update |  | ||||||
|     apt-get -yq2 dist-upgrade |  | ||||||
| else |  | ||||||
|     echo "# Adding Ondrej PHP $PHPVER PPA Repository" |  | ||||||
|     add_gpg_keyring E5267A6C |  | ||||||
|     echo "deb [arch=amd64] http://ppa.launchpad.net/ondrej/php/ubuntu $DISTRO_RELEASE main" > /etc/apt/sources.list.d/php"$PHPVER".list |  | ||||||
|     apt-get update -q2 |  | ||||||
| fi |  | ||||||
| } |  | ||||||
| while [[ "$ANS_NCD" != "yes" ]] | while [[ "$ANS_NCD" != "yes" ]] | ||||||
| do | do | ||||||
|   read -p "> Please set your domain (or subdomain) here for Nextcloud: (e.g.: cloud.domain.com)$NL" -r NC_DOMAIN |   read -p "> Please set your domain (or subdomain) here for Nextcloud: (e.g.: cloud.domain.com)$NL" -r NC_DOMAIN | ||||||
|  | @ -132,9 +95,11 @@ do | ||||||
|     echo "   - Please try again." |     echo "   - Please try again." | ||||||
|   fi |   fi | ||||||
| done | done | ||||||
|  | sleep .1 | ||||||
|   #Simple DNS test |   #Simple DNS test | ||||||
| if [ "$PUBLIC_IP" = "$(dig -4 +short "$NC_DOMAIN"|awk -v RS='([0-9]+\\.){3}[0-9]+' 'RT{print RT}')" ]; then | if [ "$PUBLIC_IP" = "$(dig -4 +short "$NC_DOMAIN"|awk -v RS='([0-9]+\\.){3}[0-9]+' 'RT{print RT}')" ]; then | ||||||
|   echo -e "Server public IP  & DNS record for $NC_DOMAIN seems to match, continuing...\n\n" |   echo -e "Server public IP  & DNS record for $NC_DOMAIN seems to match, continuing...\n\n" | ||||||
|  |   sleep .1 | ||||||
| else | else | ||||||
|   echo "Server public IP ($PUBLIC_IP) & DNS record for $NC_DOMAIN don't seem to match." |   echo "Server public IP ($PUBLIC_IP) & DNS record for $NC_DOMAIN don't seem to match." | ||||||
|   echo "  > Please check your dns records are applied and updated, otherwise Nextcloud may fail." |   echo "  > Please check your dns records are applied and updated, otherwise Nextcloud may fail." | ||||||
|  | @ -146,7 +111,7 @@ else | ||||||
|   exit |   exit | ||||||
|   fi |   fi | ||||||
| fi | fi | ||||||
| 
 | sleep .1 | ||||||
| NC_NGINX_CONF="/etc/nginx/sites-available/$NC_DOMAIN.conf" | NC_NGINX_CONF="/etc/nginx/sites-available/$NC_DOMAIN.conf" | ||||||
| while [ -z "$NC_USER" ] | while [ -z "$NC_USER" ] | ||||||
| do | do | ||||||
|  | @ -155,6 +120,7 @@ do | ||||||
|         echo " - This field is mandatory." |         echo " - This field is mandatory." | ||||||
|     fi |     fi | ||||||
| done | done | ||||||
|  | sleep .1 | ||||||
| while [ -z "$NC_PASS" ]  || [ ${#NC_PASS} -lt 8 ] | while [ -z "$NC_PASS" ]  || [ ${#NC_PASS} -lt 8 ] | ||||||
| do | do | ||||||
|     read -p "Nextcloud user password: " -r NC_PASS |     read -p "Nextcloud user password: " -r NC_PASS | ||||||
|  | @ -162,6 +128,7 @@ do | ||||||
|         echo -e " - This field is mandatory. \nPlease make sure it's at least 8 characters.\n" |         echo -e " - This field is mandatory. \nPlease make sure it's at least 8 characters.\n" | ||||||
|     fi |     fi | ||||||
| done | done | ||||||
|  | sleep .1 | ||||||
| #Enable HSTS | #Enable HSTS | ||||||
| while [ "$ENABLE_HSTS" != "yes" ] && [ "$ENABLE_HSTS" != "no" ] | while [ "$ENABLE_HSTS" != "yes" ] && [ "$ENABLE_HSTS" != "no" ] | ||||||
| do | do | ||||||
|  | @ -174,7 +141,7 @@ do | ||||||
|         echo " - HSTS will be enabled." |         echo " - HSTS will be enabled." | ||||||
|     fi |     fi | ||||||
| done | done | ||||||
| 
 | sleep .1 | ||||||
| echo -e "#Default country phone code\n | echo -e "#Default country phone code\n | ||||||
| > Starting at Nextcloud 21.x it's required to set a default country phone ISO 3166-1 alpha-2 code.\n | > Starting at Nextcloud 21.x it's required to set a default country phone ISO 3166-1 alpha-2 code.\n | ||||||
| >>> https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2#Officially_assigned_code_elements  <<<\n" | >>> https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2#Officially_assigned_code_elements  <<<\n" | ||||||
|  | @ -209,241 +176,39 @@ exit_ifinstalled postgresql-"$PSGVER" | ||||||
| # PostgresSQL | # PostgresSQL | ||||||
| install_ifnot postgresql-"$PSGVER" | install_ifnot postgresql-"$PSGVER" | ||||||
| 
 | 
 | ||||||
| # PHP 7.4 / 8.1 |  | ||||||
| add_php |  | ||||||
| install_aval_package " \ |  | ||||||
|             imagemagick \ |  | ||||||
|             php$PHPVER-fpm \ |  | ||||||
|             php$PHPVER-bcmath \ |  | ||||||
|             php$PHPVER-bz2 \ |  | ||||||
|             php$PHPVER-curl \ |  | ||||||
|             php$PHPVER-gd \ |  | ||||||
|             php$PHPVER-gmp \ |  | ||||||
|             php$PHPVER-imagick \ |  | ||||||
|             php$PHPVER-intl \ |  | ||||||
|             php$PHPVER-json \ |  | ||||||
|             php$PHPVER-ldap \ |  | ||||||
|             php$PHPVER-mbstring \ |  | ||||||
|             php$PHPVER-pgsql \ |  | ||||||
|             php$PHPVER-redis \ |  | ||||||
|             php$PHPVER-soap \ |  | ||||||
|             php$PHPVER-xml \ |  | ||||||
|             php$PHPVER-xmlrpc \ |  | ||||||
|             php$PHPVER-zip \ |  | ||||||
|             redis-server \ |  | ||||||
|             unzip \ |  | ||||||
|             " |  | ||||||
| 
 | 
 | ||||||
| #System related | #-------------------------------------------------- | ||||||
| install_ifnot smbclient | # Prepare PHP | ||||||
| sed -i "s|.*env\[HOSTNAME\].*|env\[HOSTNAME\] = \$HOSTNAME|" "$PHP_CONF" | #-------------------------------------------------- | ||||||
| sed -i "s|.*env\[PATH\].*|env\[PATH\] = /usr/local/bin:/usr/bin:/bin|" "$PHP_CONF" |  | ||||||
| sed -i "s|.*env\[TMP\].*|env\[TMP\] = /tmp|" "$PHP_CONF" |  | ||||||
| sed -i "s|.*env\[TMPDIR\].*|env\[TMPDIR\] = /tmp|" "$PHP_CONF" |  | ||||||
| sed -i "s|.*env\[TEMP\].*|env\[TEMP\] = /tmp|" "$PHP_CONF" |  | ||||||
| sed -i "s|;clear_env = no|clear_env = no|" "$PHP_CONF" |  | ||||||
| 
 | 
 | ||||||
| echo " | if [ "$MODE" = "debug" ]; then | ||||||
| Tunning PHP.ini... |     bash -x "$PWD"/tools/prepare_php.sh "$MIN_PHP" | ||||||
| " | else | ||||||
| # Change values in php.ini (increase max file size) |     bash "$PWD"/tools/prepare_php.sh "$MIN_PHP" | ||||||
| # max_execution_time | fi | ||||||
| sed -i "s|max_execution_time =.*|max_execution_time = 3500|g" "$PHP_INI" |  | ||||||
| # max_input_time |  | ||||||
| sed -i "s|max_input_time =.*|max_input_time = 3600|g" "$PHP_INI" |  | ||||||
| # memory_limit |  | ||||||
| sed -i "s|memory_limit =.*|memory_limit = 512M|g" "$PHP_INI" |  | ||||||
| # post_max |  | ||||||
| sed -i "s|post_max_size =.*|post_max_size = 1025M|g" "$PHP_INI" |  | ||||||
| # upload_max |  | ||||||
| sed -i "s|upload_max_filesize =.*|upload_max_filesize = 1024M|g" "$PHP_INI" |  | ||||||
| 
 |  | ||||||
| phpenmod opcache |  | ||||||
| { |  | ||||||
| 
 |  | ||||||
| echo "# OPcache settings for Nextcloud" |  | ||||||
| echo "opcache.enable=1" |  | ||||||
| echo "opcache.enable_cli=1" |  | ||||||
| echo "opcache.interned_strings_buffer=8" |  | ||||||
| echo "opcache.max_accelerated_files=10000" |  | ||||||
| echo "opcache.memory_consumption=256" |  | ||||||
| echo "opcache.save_comments=1" |  | ||||||
| echo "opcache.revalidate_freq=1" |  | ||||||
| echo "opcache.validate_timestamps=1" |  | ||||||
| } >> "$PHP_INI" |  | ||||||
| 
 |  | ||||||
| systemctl restart php"$PHPVER"-fpm.service |  | ||||||
| 
 | 
 | ||||||
| #-------------------------------------------------- | #-------------------------------------------------- | ||||||
| # Create DB user | # Create DB user | ||||||
| #-------------------------------------------------- | #-------------------------------------------------- | ||||||
| 
 | 
 | ||||||
| echo -e "\n---- Creating the PgSQL DB & User  ----" | echo -e "\n---- Creating the PgSQL DB & User  ----" | ||||||
| cd /tmp || return |  | ||||||
| sudo -u postgres psql <<DB | sudo -u postgres psql <<DB | ||||||
| CREATE DATABASE nextcloud_db; | CREATE DATABASE nextcloud_db; | ||||||
| CREATE USER ${NC_DB_USER} WITH ENCRYPTED PASSWORD '${NC_DB_PASSWD}'; | CREATE USER ${NC_DB_USER} WITH ENCRYPTED PASSWORD '${NC_DB_PASSWD}'; | ||||||
| GRANT ALL PRIVILEGES ON DATABASE ${NC_DB} TO ${NC_DB_USER}; | GRANT ALL PRIVILEGES ON DATABASE ${NC_DB} TO ${NC_DB_USER}; | ||||||
| DB | DB | ||||||
| echo "Done! | echo -e "\nDone!\n" | ||||||
| " |  | ||||||
| 
 | 
 | ||||||
| #nginx - configuration | # Add .mjs as a file extension for javascript | ||||||
| cat << NC_NGINX > "$NC_NGINX_CONF" | sed -i "/application\/javascript/s|js.*;|js mjs;|" /etc/nginx/mime.types | ||||||
| #nextcloud config |  | ||||||
| upstream php-handler { |  | ||||||
|     #server 127.0.0.1:9000; |  | ||||||
|     server unix:/run/php/php${PHPVER}-fpm.sock; |  | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| server { | # nginx conf setup. | ||||||
|     listen 80; | cp files/nextcloud.conf "$NC_NGINX_CONF" | ||||||
|     listen [::]:80; | sed -i "s|_PHPVER|$MIN_PHP|g" "$NC_NGINX_CONF" | ||||||
|     server_name $NC_DOMAIN; | sed -i "s|_NC_DOMAIN|$NC_DOMAIN|g" "$NC_NGINX_CONF" | ||||||
|     # enforce https | sed -i "s|_NC_NGINX_SSL_PORT|$NC_NGINX_SSL_PORT|g" "$NC_NGINX_CONF" | ||||||
|     return 301 https://\$server_name\$request_uri; | sed -i "s|_NC_PATH|$NC_PATH|g" "$NC_NGINX_CONF" | ||||||
| } |  | ||||||
| 
 | 
 | ||||||
| server { |  | ||||||
|     listen $NC_NGINX_SSL_PORT ssl http2; |  | ||||||
|     listen [::]:$NC_NGINX_SSL_PORT ssl http2; |  | ||||||
|     server_name $NC_DOMAIN; |  | ||||||
| 
 |  | ||||||
|     ssl_certificate /etc/letsencrypt/live/$NC_DOMAIN/fullchain.pem; |  | ||||||
|     ssl_certificate_key /etc/letsencrypt/live/$NC_DOMAIN/privkey.pem; |  | ||||||
| 
 |  | ||||||
|     # HSTS settings |  | ||||||
|     # WARNING: Only add the preload option once you read about |  | ||||||
|     # the consequences in https://hstspreload.org/. This option |  | ||||||
|     # will add the domain to a hardcoded list that is shipped |  | ||||||
|     # in all major browsers and getting removed from this list |  | ||||||
|     # could take several months. |  | ||||||
|     #add_header Strict-Transport-Security "max-age=15768000; includeSubDomains; preload;" always; |  | ||||||
| 
 |  | ||||||
|    # Enable gzip but do not remove ETag headers |  | ||||||
|     gzip on; |  | ||||||
|     gzip_vary on; |  | ||||||
|     gzip_comp_level 4; |  | ||||||
|     gzip_min_length 256; |  | ||||||
|     gzip_proxied expired no-cache no-store private no_last_modified no_etag auth; |  | ||||||
|     gzip_types application/atom+xml application/javascript application/json application/ld+json application/manifest+json application/rss+xml application/vnd.geo+json application/vnd.ms-fontobject application/x-font-ttf application/x-web-app-manifest+json application/xhtml+xml application/xml font/opentype image/bmp image/svg+xml image/x-icon text/cache-manifest text/css text/plain text/vcard text/vnd.rim.location.xloc text/vtt text/x-component text/x-cross-domain-policy; |  | ||||||
| 
 |  | ||||||
|     # Pagespeed is not supported by Nextcloud, so if your server is built |  | ||||||
|     # with the \`ngx_pagespeed\` module, uncomment this line to disable it. |  | ||||||
|     #pagespeed off; |  | ||||||
| 
 |  | ||||||
|     # HTTP response headers borrowed from Nextcloud \`.htaccess\` |  | ||||||
|     add_header Referrer-Policy                      "no-referrer"   always; |  | ||||||
|     add_header X-Content-Type-Options               "nosniff"       always; |  | ||||||
|     add_header X-Download-Options                   "noopen"        always; |  | ||||||
|     add_header X-Frame-Options                      "SAMEORIGIN"    always; |  | ||||||
|     add_header X-Permitted-Cross-Domain-Policies    "none"          always; |  | ||||||
|     add_header X-Robots-Tag                         "none"          always; |  | ||||||
|     add_header X-XSS-Protection                     "1; mode=block" always; |  | ||||||
| 
 |  | ||||||
|     # Remove X-Powered-By, which is an information leak |  | ||||||
|     fastcgi_hide_header X-Powered-By; |  | ||||||
| 
 |  | ||||||
|     # set max upload size |  | ||||||
|     client_max_body_size 1024M; |  | ||||||
|     fastcgi_buffers 64 4K; |  | ||||||
| 
 |  | ||||||
|     # Path to the root of your installation |  | ||||||
|     root $NC_PATH/; |  | ||||||
| 
 |  | ||||||
|     # Specify how to handle directories -- specifying \`/index.php\$request_uri\` |  | ||||||
|     # here as the fallback means that Nginx always exhibits the desired behaviour |  | ||||||
|     # when a client requests a path that corresponds to a directory that exists |  | ||||||
|     # on the server. In particular, if that directory contains an index.php file, |  | ||||||
|     # that file is correctly served; if it doesn't, then the request is passed to |  | ||||||
|     # the front-end controller. This consistent behaviour means that we don't need |  | ||||||
|     # to specify custom rules for certain paths (e.g. images and other assets, |  | ||||||
|     # \`/updater\`, \`/ocm-provider\`, \`/ocs-provider\`), and thus |  | ||||||
|     # \`try_files \$uri \$uri/ /index.php\$request_uri\` |  | ||||||
|     # always provides the desired behaviour. |  | ||||||
|     index index.php index.html /index.php\$request_uri; |  | ||||||
| 
 |  | ||||||
|     # Rule borrowed from \`.htaccess\` to handle Microsoft DAV clients |  | ||||||
|     location = / { |  | ||||||
|         if ( \$http_user_agent ~ ^DavClnt ) { |  | ||||||
|             return 302 /remote.php/webdav/\$is_args\$args; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     location = /robots.txt { |  | ||||||
|         allow all; |  | ||||||
|         log_not_found off; |  | ||||||
|         access_log off; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     # Make a regex exception for \`/.well-known\` so that clients can still |  | ||||||
|     # access it despite the existence of the regex rule |  | ||||||
|     # \`location ~ /(\.|autotest|...)\` which would otherwise handle requests |  | ||||||
|     # for \`/.well-known\`. |  | ||||||
|     location ^~ /.well-known { |  | ||||||
|         # The rules in this block are an adaptation of the rules |  | ||||||
|         # in \`.htaccess\` that concern \`/.well-known\`. |  | ||||||
| 
 |  | ||||||
|         location = /.well-known/carddav { return 301 /remote.php/dav/; } |  | ||||||
|         location = /.well-known/caldav  { return 301 /remote.php/dav/; } |  | ||||||
| 
 |  | ||||||
|         location /.well-known/acme-challenge    { try_files \$uri \$uri/ =404; } |  | ||||||
|         location /.well-known/pki-validation    { try_files \$uri \$uri/ =404; } |  | ||||||
| 
 |  | ||||||
|         # Let Nextcloud's API for \`/.well-known\` URIs handle all other |  | ||||||
|         # requests by passing them to the front-end controller. |  | ||||||
|         return 301 /index.php\$request_uri; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     # Rules borrowed from \`.htaccess\` to hide certain paths from clients |  | ||||||
|     location ~ ^/(?:build|tests|config|lib|3rdparty|templates|data)(?:\$|/)  { return 404; } |  | ||||||
|     location ~ ^/(?:\.|autotest|occ|issue|indie|db_|console)                { return 404; } |  | ||||||
| 
 |  | ||||||
|     # Ensure this block, which passes PHP files to the PHP process, is above the blocks |  | ||||||
|     # which handle static assets (as seen below). If this block is not declared first, |  | ||||||
|     # then Nginx will encounter an infinite rewriting loop when it prepends \`/index.php\` |  | ||||||
|     # to the URI, resulting in a HTTP 500 error response. |  | ||||||
|     location ~ \.php(?:\$|/) { |  | ||||||
|         fastcgi_split_path_info ^(.+?\.php)(/.*)\$; |  | ||||||
|         set \$path_info \$fastcgi_path_info; |  | ||||||
| 
 |  | ||||||
|         try_files \$fastcgi_script_name =404; |  | ||||||
| 
 |  | ||||||
|         include fastcgi_params; |  | ||||||
|         fastcgi_param SCRIPT_FILENAME \$document_root\$fastcgi_script_name; |  | ||||||
|         fastcgi_param PATH_INFO \$path_info; |  | ||||||
|         fastcgi_param HTTPS on; |  | ||||||
| 
 |  | ||||||
|         fastcgi_param modHeadersAvailable true;         # Avoid sending the security headers twice |  | ||||||
|         fastcgi_param front_controller_active true;     # Enable pretty urls |  | ||||||
|         fastcgi_pass php-handler; |  | ||||||
| 
 |  | ||||||
|         fastcgi_intercept_errors on; |  | ||||||
|         fastcgi_request_buffering off; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     location ~ \.(?:css|js|svg|gif)\$ { |  | ||||||
|         try_files \$uri /index.php\$request_uri; |  | ||||||
|         expires 6M;         # Cache-Control policy borrowed from \`.htaccess\` |  | ||||||
|         access_log off;     # Optional: Don't log access to assets |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     location ~ \.woff2?\$ { |  | ||||||
|         try_files \$uri /index.php\$request_uri; |  | ||||||
|         expires 7d;         # Cache-Control policy borrowed from \`.htaccess\` |  | ||||||
|         access_log off;     # Optional: Don't log access to assets |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     # Rule borrowed from \`.htaccess\` |  | ||||||
|     location /remote { |  | ||||||
|         return 301 /remote.php\$request_uri; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     location / { |  | ||||||
|         try_files \$uri \$uri/ /index.php\$request_uri; |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| NC_NGINX |  | ||||||
| systemctl stop nginx | systemctl stop nginx | ||||||
| letsencrypt certonly --standalone --renew-by-default --agree-tos -d "$NC_DOMAIN" | letsencrypt certonly --standalone --renew-by-default --agree-tos -d "$NC_DOMAIN" | ||||||
| if [ -f /etc/letsencrypt/live/"$NC_DOMAIN"/fullchain.pem ];then | if [ -f /etc/letsencrypt/live/"$NC_DOMAIN"/fullchain.pem ];then | ||||||
|  | @ -479,7 +244,7 @@ chown -R www-data:www-data "$NC_PATH" | ||||||
| chmod -R 755 "$NC_PATH" | chmod -R 755 "$NC_PATH" | ||||||
| 
 | 
 | ||||||
| echo -e "\nDatabase installation...\n" | echo -e "\nDatabase installation...\n" | ||||||
| sudo -u www-data php "$NC_PATH"/occ maintenance:install \ | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ maintenance:install \ | ||||||
| --database=pgsql \ | --database=pgsql \ | ||||||
| --database-name="$NC_DB" \ | --database-name="$NC_DB" \ | ||||||
| --database-user="$NC_DB_USER" \ | --database-user="$NC_DB_USER" \ | ||||||
|  | @ -494,7 +259,7 @@ sed -i "/simpleSignUpLink.shown/a \ \ \'knowledgebaseenabled\' => false," "$NC_C | ||||||
| sed -i "s|http://localhost|https://$NC_DOMAIN|" "$NC_CONFIG" | sed -i "s|http://localhost|https://$NC_DOMAIN|" "$NC_CONFIG" | ||||||
| 
 | 
 | ||||||
| echo -e "\nAdd crontab...\n" | echo -e "\nAdd crontab...\n" | ||||||
| crontab -u www-data -l | { cat; echo "*/5  *  *  *  * php -f $NC_PATH/cron.php"; } | crontab -u www-data - | crontab -u www-data -l | { cat; echo "*/5  *  *  *  * php$MIN_PHP -f $NC_PATH/cron.php"; } | crontab -u www-data - | ||||||
| 
 | 
 | ||||||
| echo -e "\nAdd memcache support...\n" | echo -e "\nAdd memcache support...\n" | ||||||
| sed -i "s|# unixsocket .*|unixsocket /var/run/redis/redis.sock|g" "$REDIS_CONF" | sed -i "s|# unixsocket .*|unixsocket /var/run/redis/redis.sock|g" "$REDIS_CONF" | ||||||
|  | @ -520,25 +285,24 @@ sed -i "/);/i \ \ )," "$NC_CONFIG" | ||||||
| echo -e "Done\n" | echo -e "Done\n" | ||||||
| 
 | 
 | ||||||
| echo -e "\nAddding & Setting up Files External App for Local storage...\n" | echo -e "\nAddding & Setting up Files External App for Local storage...\n" | ||||||
| sudo -u www-data php "$NC_PATH"/occ app:install files_external | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ app:install files_external | ||||||
| sudo -u www-data php "$NC_PATH"/occ app:enable files_external | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ app:enable files_external | ||||||
| sudo -u www-data php "$NC_PATH"/occ app:disable support | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ app:disable support | ||||||
| sudo -u www-data php "$NC_PATH"/occ files_external:import /tmp/jra-nc-app-ef.json | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ files_external:import /tmp/jra-nc-app-ef.json | ||||||
| 
 | 
 | ||||||
| usermod -a -G jibri www-data | usermod -a -G jibri www-data | ||||||
| chmod -R 770 "$DIR_RECORD" | chmod -R 770 "$DIR_RECORD" | ||||||
| chmod -R g+s "$DIR_RECORD" | chmod -R g+s "$DIR_RECORD" | ||||||
| 
 | 
 | ||||||
| echo -e "\nFixing possible missing tables...\n\n" | echo -e "\nFixing possible missing tables...\n\n" | ||||||
| echo "y"|sudo -u www-data php "$NC_PATH"/occ db:convert-filecache-bigint | echo "y"|sudo -u www-data php$MIN_PHP "$NC_PATH"/occ db:convert-filecache-bigint | ||||||
| sudo -u www-data php "$NC_PATH"/occ db:add-missing-indices | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ db:add-missing-indices | ||||||
| sudo -u www-data php "$NC_PATH"/occ db:add-missing-columns | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ db:add-missing-columns | ||||||
| 
 | 
 | ||||||
| echo -e "\nAdding trusted domain...\n" | echo -e "\nAdding trusted domain...\n" | ||||||
| sudo -u www-data php "$NC_PATH"/occ config:system:set trusted_domains 0 --value="$NC_DOMAIN" | sudo -u www-data php$MIN_PHP "$NC_PATH"/occ config:system:set trusted_domains 0 --value="$NC_DOMAIN" | ||||||
| 
 | 
 | ||||||
| echo -e "\nSetting JRA domain on jitsi-updater.sh\n" | echo -e "\nSetting JRA domain on jitsi-updater.sh\n" | ||||||
| cd ~/quick-jibri-installer || return |  | ||||||
| sed -i "s|NC_DOMAIN=.*|NC_DOMAIN=\"$NC_DOMAIN\"|" jitsi-updater.sh | sed -i "s|NC_DOMAIN=.*|NC_DOMAIN=\"$NC_DOMAIN\"|" jitsi-updater.sh | ||||||
| 
 | 
 | ||||||
| echo -e "\nQuick Nextcloud installation complete!\n" | echo -e "\nQuick Nextcloud installation complete!\n" | ||||||
|  |  | ||||||
|  | @ -131,6 +131,7 @@ add_prosody_repo() { | ||||||
|             > /etc/apt/sources.list.d/prosody.list |             > /etc/apt/sources.list.d/prosody.list | ||||||
|         curl -s https://prosody.im/files/prosody-debian-packages.key \ |         curl -s https://prosody.im/files/prosody-debian-packages.key \ | ||||||
|             > "$PROSODY_GPG_KEY" |             > "$PROSODY_GPG_KEY" | ||||||
|  |         apt-get update -q2 | ||||||
|     fi |     fi | ||||||
| } | } | ||||||
| dpkg-compare() { | dpkg-compare() { | ||||||
|  | @ -317,6 +318,7 @@ else | ||||||
|         > /etc/apt/sources.list.d/jitsi-stable.list |         > /etc/apt/sources.list.d/jitsi-stable.list | ||||||
|     curl -s https://download.jitsi.org/jitsi-key.gpg.key \ |     curl -s https://download.jitsi.org/jitsi-key.gpg.key \ | ||||||
|         > "$JITSI_GPG_KEY" |         > "$JITSI_GPG_KEY" | ||||||
|  |     apt-get update -q2 | ||||||
|     JITSI_REPO="stable" |     JITSI_REPO="stable" | ||||||
| fi | fi | ||||||
| sleep .1 | sleep .1 | ||||||
|  | @ -452,7 +454,7 @@ else | ||||||
|         | gpg --dearmor -o "$NODEJS_GPG_KEY" |         | gpg --dearmor -o "$NODEJS_GPG_KEY" | ||||||
|     echo "deb [signed-by=$NODEJS_GPG_KEY] https://deb.nodesource.com/node_$NODEJS_VER.x nodistro main" | \ |     echo "deb [signed-by=$NODEJS_GPG_KEY] https://deb.nodesource.com/node_$NODEJS_VER.x nodistro main" | \ | ||||||
|         tee /etc/apt/sources.list.d/nodesource.list |         tee /etc/apt/sources.list.d/nodesource.list | ||||||
|     apt-get update -yq2 |     apt-get update -q2 | ||||||
|     apt-get install -yq2 nodejs |     apt-get install -yq2 nodejs | ||||||
| 
 | 
 | ||||||
|     echo "Installing nodejs esprima package..." |     echo "Installing nodejs esprima package..." | ||||||
|  |  | ||||||
|  | @ -0,0 +1,138 @@ | ||||||
|  | #!/bin/bash | ||||||
|  | # Automated PHP environment build for Nextcloud. | ||||||
|  | # SwITNet Ltd © - 2024, https://switnet.net/ | ||||||
|  | # GPLv3 or later. | ||||||
|  | 
 | ||||||
|  | PHPVER=$1 | ||||||
|  | STABLE_PHP="$(apt-cache madison php|grep -v ppa|awk -F'[:+]' 'NR==1{print $2}')" | ||||||
|  | DISTRO_RELEASE="$(lsb_release -sc)" | ||||||
|  | PHP_REPO="$(apt-cache policy | awk '/http/&&/php/{print$2}' | awk -F "/" 'NR==1{print$5}')" | ||||||
|  | PHP_REPO_URL="http://ppa.launchpad.net/ondrej/php/ubuntu" | ||||||
|  | PHP_FPM_DIR="/etc/php/$PHPVER/fpm" | ||||||
|  | PHP_INI="$PHP_FPM_DIR/php.ini" | ||||||
|  | PHP_CONF="/etc/php/$PHPVER/fpm/pool.d/www.conf" | ||||||
|  | TMP_GPG_REPO="$(mktemp -d)" | ||||||
|  | 
 | ||||||
|  | if [ $# -ne 1 ]; then | ||||||
|  |   echo "Usage: $0 8.2" | ||||||
|  |   exit 1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | install_ifnot() { | ||||||
|  |     if [ "$(dpkg-query -W -f='${Status}' "$1" 2>/dev/null | grep -c "ok installed")" == "1" ]; then | ||||||
|  |         echo " $1 is installed, skipping..." | ||||||
|  |     else | ||||||
|  |         printf "\n---- Installing %s ----" "$1" | ||||||
|  |         apt-get -yq2 install "$1" | ||||||
|  |     fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | install_aval_package() { | ||||||
|  | for i in $1 | ||||||
|  |   do | ||||||
|  |      if [ -z "$(apt-cache madison "$i" 2>/dev/null)" ]; then | ||||||
|  |      echo " > Package $i not available on repo." | ||||||
|  |      else | ||||||
|  |      echo " > Add package $i to the install list" | ||||||
|  |      packages="$packages $i" | ||||||
|  |      fi | ||||||
|  |  done | ||||||
|  |  echo "$packages" | ||||||
|  |  apt-get -y install $packages #< don't quote. | ||||||
|  |  packages="" | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | add_gpg_keyring() { | ||||||
|  | apt-key adv --recv-keys --keyserver keyserver.ubuntu.com "$1" | ||||||
|  | apt-key export "$1" | gpg --dearmour | tee "$TMP_GPG_REPO"/"$1".gpg >/dev/null | ||||||
|  | apt-key del "$1" | ||||||
|  | mv "$TMP_GPG_REPO"/"$1".gpg /etc/apt/trusted.gpg.d/ | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | add_php_repo() { | ||||||
|  | if [ "$PHP_REPO" = "php" ]; then | ||||||
|  |     echo "PHP $PHPVER already installed" | ||||||
|  |     apt-get -q2 update | ||||||
|  |     apt-get -yq2 dist-upgrade | ||||||
|  | else | ||||||
|  |     echo "# Adding Ondrej PHP $PHPVER PPA Repository" | ||||||
|  |     add_gpg_keyring E5267A6C | ||||||
|  |     echo "deb [arch=amd64] $PHP_REPO_URL $DISTRO_RELEASE main" | \ | ||||||
|  |     tee /etc/apt/sources.list.d/php"$PHPVER".list | ||||||
|  |     apt-get update -q2 | ||||||
|  | fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | add_php_repo | ||||||
|  | 
 | ||||||
|  | install_aval_package " \ | ||||||
|  |             imagemagick \ | ||||||
|  |             php$PHPVER-fpm \ | ||||||
|  |             php$PHPVER-bcmath \ | ||||||
|  |             php$PHPVER-bz2 \ | ||||||
|  |             php$PHPVER-cli \ | ||||||
|  |             php$PHPVER-cgi \ | ||||||
|  |             php$PHPVER-curl \ | ||||||
|  |             php$PHPVER-gd \ | ||||||
|  |             php$PHPVER-gmp \ | ||||||
|  |             php$PHPVER-imagick \ | ||||||
|  |             php$PHPVER-intl \ | ||||||
|  |             php$PHPVER-json \ | ||||||
|  |             php$PHPVER-ldap \ | ||||||
|  |             php$PHPVER-mbstring \ | ||||||
|  |             php$PHPVER-pgsql \ | ||||||
|  |             php$PHPVER-redis \ | ||||||
|  |             php$PHPVER-soap \ | ||||||
|  |             php$PHPVER-xml \ | ||||||
|  |             php$PHPVER-xmlrpc \ | ||||||
|  |             php$PHPVER-zip \ | ||||||
|  |             redis-server \ | ||||||
|  |             unzip \ | ||||||
|  |             " | ||||||
|  | 
 | ||||||
|  | #System related | ||||||
|  | install_ifnot smbclient | ||||||
|  | sed -i "s|.*env\[HOSTNAME\].*|env\[HOSTNAME\] = \$HOSTNAME|" "$PHP_CONF" | ||||||
|  | sed -i "s|.*env\[PATH\].*|env\[PATH\] = /usr/local/bin:/usr/bin:/bin|" "$PHP_CONF" | ||||||
|  | sed -i "s|.*env\[TMP\].*|env\[TMP\] = /tmp|" "$PHP_CONF" | ||||||
|  | sed -i "s|.*env\[TMPDIR\].*|env\[TMPDIR\] = /tmp|" "$PHP_CONF" | ||||||
|  | sed -i "s|.*env\[TEMP\].*|env\[TEMP\] = /tmp|" "$PHP_CONF" | ||||||
|  | sed -i "s|;clear_env = no|clear_env = no|" "$PHP_CONF" | ||||||
|  | 
 | ||||||
|  | echo " | ||||||
|  | Tunning PHP.ini... | ||||||
|  | " | ||||||
|  | # Change values in php.ini (increase max file size) | ||||||
|  | # max_execution_time | ||||||
|  | sed -i "s|max_execution_time =.*|max_execution_time = 3500|g" "$PHP_INI" | ||||||
|  | # max_input_time | ||||||
|  | sed -i "s|max_input_time =.*|max_input_time = 3600|g" "$PHP_INI" | ||||||
|  | # memory_limit | ||||||
|  | sed -i "s|memory_limit =.*|memory_limit = 512M|g" "$PHP_INI" | ||||||
|  | # post_max | ||||||
|  | sed -i "s|post_max_size =.*|post_max_size = 1025M|g" "$PHP_INI" | ||||||
|  | # upload_max | ||||||
|  | sed -i "s|upload_max_filesize =.*|upload_max_filesize = 1024M|g" "$PHP_INI" | ||||||
|  | 
 | ||||||
|  | phpenmod opcache | ||||||
|  | { | ||||||
|  | 
 | ||||||
|  | echo "# OPcache settings for Nextcloud" | ||||||
|  | echo "opcache.enable=1" | ||||||
|  | echo "opcache.enable_cli=1" | ||||||
|  | echo "opcache.interned_strings_buffer=8" | ||||||
|  | echo "opcache.max_accelerated_files=10000" | ||||||
|  | echo "opcache.memory_consumption=256" | ||||||
|  | echo "opcache.save_comments=1" | ||||||
|  | echo "opcache.revalidate_freq=1" | ||||||
|  | echo "opcache.validate_timestamps=1" | ||||||
|  | } >> "$PHP_INI" | ||||||
|  | 
 | ||||||
|  | update-alternatives --set php           /usr/bin/php"$STABLE_PHP" | ||||||
|  | update-alternatives --set php-fpm.sock  /run/php/php"$STABLE_PHP"-fpm.sock | ||||||
|  | update-alternatives --set php-cgi      	/usr/bin/php-cgi"$STABLE_PHP" | ||||||
|  | update-alternatives --set php-cgi-bin   /usr/lib/cgi-bin/php"$STABLE_PHP" | ||||||
|  | update-alternatives --set phar          /usr/bin/phar"$STABLE_PHP" | ||||||
|  | update-alternatives --set phar.phar     /usr/bin/phar.phar"$STABLE_PHP" | ||||||
|  | 
 | ||||||
|  | systemctl restart php"$PHPVER"-fpm.service | ||||||
		Loading…
	
		Reference in New Issue