|
| 1 | +#!/bin/bash |
| 2 | +# info: add/remove HSTS support from a domain |
| 3 | +# options: USER DOMAIN STATUS |
| 4 | +# |
| 5 | +# This function will enable or disable HSTS (HTTP Strict Transport Security) |
| 6 | +# for a web domain. |
| 7 | + |
| 8 | + |
| 9 | +#----------------------------------------------------------# |
| 10 | +# Variable&Function # |
| 11 | +#----------------------------------------------------------# |
| 12 | + |
| 13 | +# Argument definition |
| 14 | +user=$1 |
| 15 | +domain=$2 |
| 16 | +domain_idn=$2 |
| 17 | +status=$3 |
| 18 | + |
| 19 | +# Includes |
| 20 | +source $HESTIA/func/main.sh |
| 21 | +source $HESTIA/func/domain.sh |
| 22 | +source $HESTIA/conf/hestia.conf |
| 23 | + |
| 24 | +#----------------------------------------------------------# |
| 25 | +# Verifications # |
| 26 | +#----------------------------------------------------------# |
| 27 | + |
| 28 | +check_args '2' "$#" 'USER DOMAIN' |
| 29 | +is_format_valid 'user' 'domain' |
| 30 | +is_object_valid 'user' 'USER' "$user" |
| 31 | +is_object_unsuspended 'user' 'USER' "$user" |
| 32 | +is_object_valid 'web' 'DOMAIN' "$domain" |
| 33 | +is_object_unsuspended 'web' 'DOMAIN' "$domain" |
| 34 | + |
| 35 | +#----------------------------------------------------------# |
| 36 | +# Action # |
| 37 | +#----------------------------------------------------------# |
| 38 | + |
| 39 | +# Load domain data |
| 40 | +eval $(grep "DOMAIN='$domain'" $USER_DATA/web.conf) |
| 41 | + |
| 42 | +# Check if SSL is enabled |
| 43 | +if [ "$SSL" != 'yes' ]; then |
| 44 | + echo "Error: SSL is not enabled" |
| 45 | + exit $E_NOTEXIST |
| 46 | +fi |
| 47 | + |
| 48 | +# Check for Apache/Nginx or Nginx/PHP-FPM configuration |
| 49 | +if [ -z $PROXY_SYSTEM ]; then |
| 50 | + hstsconf="$HOMEDIR/$user/conf/web/$domain/$WEB_SYSTEM.hsts.conf" |
| 51 | +else |
| 52 | + hstsconf="$HOMEDIR/$user/conf/web/$domain/$PROXY_SYSTEM.hsts.conf" |
| 53 | +fi |
| 54 | + |
| 55 | +if [ "$status" = "on" ]; then |
| 56 | + echo 'add_header Strict-Transport-Security "max-age=15768000;" always;' > $hstsconf |
| 57 | + echo "HTTP Strict Transport Security (HSTS) turned on for $domain." |
| 58 | +elif [ "$status" = "off" ]; then |
| 59 | + rm -f $hstsconf |
| 60 | + nginx -s reload |
| 61 | + echo "HTTP Strict Transport Security (HSTS) turned off for $domain." |
| 62 | +else |
| 63 | + echo "Error: Invalid mode specified." |
| 64 | + echo "Usage: v-change-web-domain-hsts USER DOMAIN [ON / OFF]" |
| 65 | +fi |
| 66 | + |
| 67 | +#----------------------------------------------------------# |
| 68 | +# Hestia # |
| 69 | +#----------------------------------------------------------# |
| 70 | + |
| 71 | +# Logging |
| 72 | +log_history "Enabled HTTP Strict Transport Security on $domain." |
| 73 | +log_event "$OK" "$ARGUMENTS" |
| 74 | + |
| 75 | +exit |
0 commit comments