v-delete-web-domain-httpauth 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. #!/bin/bash
  2. # info: delete http auth user
  3. # options: USER DOMAIN AUTH_USER [RESTART]
  4. #
  5. # The call is used for deleting http auth user
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument definition
  10. user=$1
  11. domain=$2
  12. auth_user=$3
  13. restart=${4-yes}
  14. # Includes
  15. source $HESTIA/func/main.sh
  16. source $HESTIA/func/domain.sh
  17. source $HESTIA/conf/hestia.conf
  18. # Defining htpasswd file
  19. htaccess="$HOMEDIR/$user/conf/web/$domain/htaccess"
  20. htpasswd="$HOMEDIR/$user/conf/web/$domain/htpasswd"
  21. shtaccess="$HOMEDIR/$user/conf/web/s$WEB_SYSTEM.$domain.conf_htaccess"
  22. shtpasswd="$HOMEDIR/$user/conf/web/s$WEB_SYSTEM.$domain.htpasswd"
  23. #----------------------------------------------------------#
  24. # Verifications #
  25. #----------------------------------------------------------#
  26. check_args '3' "$#" 'USER DOMAIN AUTH_USER [RESTART]'
  27. is_format_valid 'user' 'domain'
  28. is_system_enabled "$WEB_SYSTEM" 'WEB_SYSTEM'
  29. is_object_valid 'user' 'USER' "$user"
  30. is_object_unsuspended 'user' 'USER' "$user"
  31. is_object_valid 'web' 'DOMAIN' "$domain"
  32. is_object_unsuspended 'web' 'DOMAIN' "$domain"
  33. is_password_valid
  34. get_domain_values 'web'
  35. if [ -z "$(echo "$AUTH_USER" |tr : '\n' |grep ^$auth_user$)" ]; then
  36. echo "Error: auth user $auth_user doesn't exist"
  37. log_event "$E_NOTEXIST" "$ARGUMENTS"
  38. exit $E_NOTEXIST
  39. fi
  40. #----------------------------------------------------------#
  41. # Action #
  42. #----------------------------------------------------------#
  43. # Deleting auth user
  44. sed -i "/^$auth_user:/d" $htpasswd
  45. # Deleting password protection
  46. if [ "$(echo "$AUTH_USER" |tr : '\n' |wc -l)" -le 1 ]; then
  47. rm -f $htaccess $htpasswd $shtaccess $shtpasswd
  48. restart_required='yes'
  49. fi
  50. # Restarting web server
  51. if [ "$restart" != 'no' ] && [ "$restart_required" = 'yes' ]; then
  52. $BIN/v-restart-web
  53. fi
  54. #----------------------------------------------------------#
  55. # Hestia #
  56. #----------------------------------------------------------#
  57. # Rebuilding FTP variables
  58. position=$(echo $AUTH_USER |tr ':' '\n' |grep -n '' |grep ":$auth_user$" |\
  59. cut -f 1 -d:)
  60. auth_user=$(echo $AUTH_USER |tr ':' '\n' |grep -n '' |grep -v "^$position:" |\
  61. cut -f 2 -d :| sed -e "/^$/d"| sed -e ':a;N;$!ba;s/\n/:/g')
  62. auth_hash=$(echo $AUTH_HASH |tr ':' '\n' |grep -n '' |grep -v "^$position:" |\
  63. cut -f 2 -d :| sed -e ':a;N;$!ba;s/\n/:/g')
  64. # Update config
  65. update_object_value 'web' 'DOMAIN' "$domain" '$AUTH_USER' "$auth_user"
  66. update_object_value 'web' 'DOMAIN' "$domain" '$AUTH_HASH' "$auth_hash"
  67. # Logging
  68. log_history "changed auth user $httpauth_user password on $domain"
  69. log_event "$OK" "$ARGUMENTS"
  70. exit