|
| 1 | +#!/bin/bash |
| 2 | +# info: add password protection for web domain |
| 3 | +# options: USER DOMAIN AUTH_USER AUTH_PASSWORD [RESTART] |
| 4 | +# |
| 5 | +# The call is used for securing web domain with http auth |
| 6 | + |
| 7 | + |
| 8 | +#----------------------------------------------------------# |
| 9 | +# Variable&Function # |
| 10 | +#----------------------------------------------------------# |
| 11 | + |
| 12 | +# Argument defenition |
| 13 | +user=$1 |
| 14 | +domain=$2 |
| 15 | +auth_user=$3 |
| 16 | +password=$4 |
| 17 | +restart=${5-yes} |
| 18 | + |
| 19 | +# Includes |
| 20 | +source $VESTA/func/main.sh |
| 21 | +source $VESTA/func/domain.sh |
| 22 | +source $VESTA/conf/vesta.conf |
| 23 | + |
| 24 | +# Hiding password |
| 25 | +A4='******' |
| 26 | +EVENT="$DATE $TIME $SCRIPT $A1 $A2 $A3 $A4 $A5 $A6 $A7 $A8 $A9" |
| 27 | + |
| 28 | +# Definining htpasswd file |
| 29 | +htaccess="$HOMEDIR/$user/conf/web/$WEB_SYSTEM.$domain.conf_htaccess" |
| 30 | +htpasswd="$HOMEDIR/$user/conf/web/$WEB_SYSTEM.$domain.htpasswd" |
| 31 | +docroot="$HOMEDIR/$user/web/$domain/public_html" |
| 32 | + |
| 33 | + |
| 34 | +#----------------------------------------------------------# |
| 35 | +# Verifications # |
| 36 | +#----------------------------------------------------------# |
| 37 | + |
| 38 | +check_args '4' "$#" 'USER DOMAIN AUTH_USER AUTH_PASSWORD [RESTART]' |
| 39 | +validate_format 'user' 'domain' |
| 40 | +is_system_enabled "$WEB_SYSTEM" 'WEB_SYSTEM' |
| 41 | +is_object_valid 'user' 'USER' "$user" |
| 42 | +is_object_unsuspended 'user' 'USER' "$user" |
| 43 | +is_object_valid 'web' 'DOMAIN' "$domain" |
| 44 | +is_object_unsuspended 'web' 'DOMAIN' "$domain" |
| 45 | +is_password_valid |
| 46 | +get_domain_values 'web' |
| 47 | +if [ ! -z "$(echo "$AUTH_USER" |tr : '\n' |grep ^$auth_user$)" ]; then |
| 48 | + echo "Error: auth user $auth_user already exists" |
| 49 | + log_event "$E_EXISTS" "$EVENT" |
| 50 | + exit $E_EXISTS |
| 51 | +fi |
| 52 | + |
| 53 | + |
| 54 | +#----------------------------------------------------------# |
| 55 | +# Action # |
| 56 | +#----------------------------------------------------------# |
| 57 | + |
| 58 | +# Adding htaccess password protection |
| 59 | +if [ ! -e "$htaccess" ]; then |
| 60 | + if [ "$WEB_SYSTEM" != 'nginx' ]; then |
| 61 | + echo "<Directory $docroot>" > $htaccess |
| 62 | + echo " AuthUserFile $htpasswd" >> $htaccess |
| 63 | + echo " AuthName \"$domain access\"" >> $htaccess |
| 64 | + echo " AuthType Basic" >> $htaccess |
| 65 | + echo " Require valid-user" >> $htaccess |
| 66 | + echo "</Directory>" >> $htaccess |
| 67 | + else |
| 68 | + echo "auth_basic \"$domain password access\";" > $htaccess |
| 69 | + echo "auth_basic_user_file $htpasswd;" >> $htaccess |
| 70 | + fi |
| 71 | + restart_required='yes' |
| 72 | +fi |
| 73 | + |
| 74 | +# Adding httpasswd user |
| 75 | +auth_hash=$($BIN/v-generate-password-hash htpasswd htpasswd $password) |
| 76 | +touch $htpasswd |
| 77 | +sed -i "/^$auth_user:/d" $htpasswd |
| 78 | +echo "$auth_user:$auth_hash" >> $htpasswd |
| 79 | + |
| 80 | +# Restarting web server |
| 81 | +if [ "$restart" != 'no' ] && [ "$restart_required" = 'yes' ]; then |
| 82 | + $BIN/v-restart-web |
| 83 | +fi |
| 84 | + |
| 85 | + |
| 86 | +#----------------------------------------------------------# |
| 87 | +# Vesta # |
| 88 | +#----------------------------------------------------------# |
| 89 | + |
| 90 | +# Preparing web.conf keys |
| 91 | +if [ ! -z "$AUTH_USER" ]; then |
| 92 | + auth_user="$AUTH_USER:$auth_user" |
| 93 | + auth_hash="$AUTH_HASH:$auth_hash" |
| 94 | +else |
| 95 | + # Adding new key into web.conf |
| 96 | + add_object_key "web" 'DOMAIN' "$domain" 'AUTH_USER' 'U_DISK' |
| 97 | + add_object_key "web" 'DOMAIN' "$domain" 'AUTH_HASH' 'U_DISK' |
| 98 | +fi |
| 99 | + |
| 100 | +# Updating config |
| 101 | +update_object_value 'web' 'DOMAIN' "$domain" '$AUTH_USER' "$auth_user" |
| 102 | +update_object_value 'web' 'DOMAIN' "$domain" '$AUTH_HASH' "$auth_hash" |
| 103 | + |
| 104 | +# Logging |
| 105 | +log_history "added http auth user $httpauth_user on $domain" |
| 106 | +log_event "$OK" "$EVENT" |
| 107 | + |
| 108 | +exit |
0 commit comments