v-delete-web-domain-httpauth 2.8 KB

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