| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 |
- #!/bin/bash
- # info: Add FastCGI nginx support
- # options: USER DOMAIN [DEBUG]
- # labels: hestia web
- #
- # example: v-add-fastcgi-cache user domain.tld
- #
- # The function enables FastCGI cache for nginx
- # Add "yes" as last parameter to append debug information to response headers
- #----------------------------------------------------------#
- # Variable&Function #
- #----------------------------------------------------------#
- # Argument definition
- user=$1
- domain=$2
- debug=$3
- # Includes
- source $HESTIA/func/main.sh
- source $HESTIA/conf/hestia.conf
- #----------------------------------------------------------#
- # Verifications #
- #----------------------------------------------------------#
- check_args '2' "$#" 'USER DOMAIN DEBUG'
- is_format_valid 'user' 'domain'
- is_object_valid 'user' 'USER' "$user"
- is_object_unsuspended 'user' 'USER' "$user"
- is_object_valid 'web' 'DOMAIN' "$domain"
- is_object_unsuspended 'web' 'DOMAIN' "$domain"
- # Perform verification if read-only mode is enabled
- check_hestia_demo_mode
- #----------------------------------------------------------#
- # Action #
- #----------------------------------------------------------#
- # Load domain data
- parse_object_kv_list $(grep "DOMAIN='$domain'" $USER_DATA/web.conf)
- # Check if nginx is not in proxy mode
- if [ "$WEB_SYSTEM" != 'nginx' ]; then
- echo "Error: nginx is in proxy mode"
- exit $E_NOTEXIST
- fi
- if ! grep --quiet "forcessl" $HESTIA/data/templates/web/nginx/default.tpl; then
- $BIN/v-update-web-templates
- fi
- fastcgi="$HOMEDIR/$user/conf/web/$domain/$WEB_SYSTEM.fastcgi_cache.conf"
- no_cache='$no_cache'
- cookie_session='$cookie_session'
- http_x_update='$http_x_update'
- status='$upstream_cache_status'
- cat << EOF > $fastcgi
- fastcgi_cache $domain;
- fastcgi_cache_valid 200 2m;
- fastcgi_cache_valid 301 302 10m;
- fastcgi_cache_valid 404 10m;
- fastcgi_cache_bypass $no_cache;
- fastcgi_no_cache $no_cache;
- EOF
- if [ ! -z "$debug" ]; then
- echo " add_header \"X-STATUS\" \"$status\";" >> $fastcgi
- fi
- chown root:$user $fastcgi
- chmod 640 $fastcgi
- str="fastcgi_cache_path /var/cache/nginx/micro/$domain levels=1:2"
- str="$str keys_zone=$domain:10m max_size=512m inactive=30m;"
- conf='/etc/nginx/conf.d/fastcgi_cache_pool.conf'
- if [ -f "$conf" ]; then
- if [ -z "$(grep "=${domain}:" $conf)" ]; then
- echo "$str" >> $conf
- fi
- else
- echo "$str" >> $conf
- fi
- mkdir -p /var/cache/nginx/micro/$domain
- #----------------------------------------------------------#
- # Hestia #
- #----------------------------------------------------------#
- if [ -z "$FASTCGI" ]; then
- add_object_key "web" 'DOMAIN' "$domain" 'FASTCGI_CACHE' 'ALIAS'
- fi
- # Set FastCGI cache flag to enabled
- update_object_value 'web' 'DOMAIN' "$domain" '$FASTCGI_CACHE' 'yes'
- # Restart web server
- $BIN/v-restart-web
- check_result $? "Web server restart failed" > /dev/null
- # Logging
- log_history "Enabled FastCGI cache for $domain"
- log_event "$OK" "$ARGUMENTS"
- exit
|