v-delete-sys-ip 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. #!/bin/bash
  2. # info: delete system ip
  3. # options: IP
  4. #
  5. # The function for deleting a system ip. It does not allow to delete first ip
  6. # on interface and do not allow to delete ip which is used by a web domain.
  7. #----------------------------------------------------------#
  8. # Variable&Function #
  9. #----------------------------------------------------------#
  10. # Argument defenition
  11. ip=$1
  12. # Includes
  13. source $VESTA/conf/vesta.conf
  14. source $VESTA/func/main.sh
  15. source $VESTA/func/ip.sh
  16. source $VESTA/func/domain.sh
  17. #----------------------------------------------------------#
  18. # Verifications #
  19. #----------------------------------------------------------#
  20. check_args '1' "$#" 'IP'
  21. validate_format 'ip'
  22. is_ip_valid "$ip"
  23. is_ip_key_empty '$U_WEB_DOMAINS'
  24. is_ip_key_empty '$U_SYS_USERS'
  25. #----------------------------------------------------------#
  26. # Action #
  27. #----------------------------------------------------------#
  28. # Get ip owner
  29. user="$(get_ip_value '$OWNER')"
  30. ip_status="$(get_ip_value '$STATUS')"
  31. # Deleting interface
  32. interface=$(/sbin/ifconfig | grep -B1 "dr:$ip " | head -n1 | cut -f1 -d \ )
  33. if [ ! -z "$interface" ] && [ -z "$(echo $interface |cut -s -f2 -d :)" ]; then
  34. echo "Error: can't delete main IP address"
  35. log_event "$E_FORBIDEN" "$EVENT"
  36. exit $E_FORBIDEN
  37. fi
  38. if [ ! -z "$interface" ]; then
  39. /sbin/ifconfig $interface down
  40. rm -f /etc/sysconfig/network-scripts/ifcfg-$interface
  41. fi
  42. # Deleting vesta ip
  43. rm -f $VESTA/data/ips/$ip
  44. # Disable virtual ip hosting support
  45. web_conf="/etc/$WEB_SYSTEM/conf.d/vesta.conf"
  46. if [ ! -z "$WEB_SYSTEM" ]; then
  47. sed -i "/NameVirtualHost $ip:/d" $web_conf
  48. sed -i "/Listen $ip:/d" $web_conf
  49. fi
  50. # Deleting proxy config
  51. if [ ! -z "$PROXY_SYSTEM" ]; then
  52. rm -f /etc/$PROXY_SYSTEM/conf.d/$ip.conf
  53. fw_conf="/etc/$WEB_SYSTEM/conf.d/mod_extract_forwarded.conf"
  54. if [ -e "$fw_conf" ]; then
  55. ips=$(grep 'MEFaccept 127.0.0.1' $fw_conf)
  56. new_ips=$(echo "$ips" | sed -e "s/$ip//" )
  57. sed -i "s/$ips/$new_ips/g" $fw_conf
  58. fi
  59. fi
  60. #----------------------------------------------------------#
  61. # Vesta #
  62. #----------------------------------------------------------#
  63. # Updating user conf
  64. if [ ! -z "$user" ]; then
  65. decrease_user_value "$user" '$IP_OWNED'
  66. fi
  67. if [ "$user" = 'admin' ]; then
  68. if [ "$ip_status" = 'shared' ]; then
  69. for user in $(ls $VESTA/data/users/); do
  70. decrease_user_value "$user" '$IP_AVAIL'
  71. done
  72. else
  73. decrease_user_value 'admin' '$IP_AVAIL'
  74. fi
  75. else
  76. decrease_user_value "$user" '$IP_AVAIL'
  77. decrease_user_value 'admin' '$IP_AVAIL'
  78. fi
  79. # Adding task to the vesta pipe
  80. $BIN/v-restart-web
  81. $BIN/v-restart-proxy
  82. # Logging
  83. log_history "deleted system ip address $ip"
  84. log_event "$OK" "$EVENT"
  85. exit