v-rebuild-web-domains 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. #!/bin/bash
  2. # info: rebuild dns domains
  3. # options: USER [RESTART]
  4. #
  5. # The function rebuilds web configuration files.
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument defenition
  10. user=$1
  11. restart=$2
  12. # Includes
  13. source $VESTA/func/main.sh
  14. source $VESTA/func/domain.sh
  15. source $VESTA/func/ip.sh
  16. source $VESTA/func/rebuild.sh
  17. source $VESTA/conf/vesta.conf
  18. #----------------------------------------------------------#
  19. # Verifications #
  20. #----------------------------------------------------------#
  21. check_args '1' "$#" 'USER [RESTART]'
  22. validate_format 'user'
  23. is_system_enabled "$WEB_SYSTEM" 'WEB_SYSTEM'
  24. is_object_valid 'user' 'USER' "$user"
  25. is_object_unsuspended 'user' 'USER' "$user"
  26. #----------------------------------------------------------#
  27. # Action #
  28. #----------------------------------------------------------#
  29. user_domains=0
  30. user_ssl=0
  31. user_aliases=0
  32. suspended_web=0
  33. conf=$USER_DATA/web.conf
  34. fields='$DOMAIN'
  35. nohead=1
  36. domain_counter=0
  37. # Clean up old config
  38. rm -f $HOMEDIR/$user/conf/tmp_*.conf
  39. # Starting loop
  40. for domain in $(shell_list); do
  41. ((++ domain_counter))
  42. rebuild_web_domain_conf
  43. done
  44. # Config path
  45. web_conf="/etc/$WEB_SYSTEM/conf.d/vesta.conf"
  46. proxy_conf="/etc/$PROXY_SYSTEM/conf.d/vesta.conf"
  47. # Touch vesta configs
  48. touch $web_conf
  49. if [ ! -z "$PROXY_SYSTEM" ]; then
  50. touch $proxy_conf
  51. fi
  52. # Checking if there is at least 1 domain
  53. if [ "$domain_counter" -lt 1 ]; then
  54. # Deleting web configs
  55. rm -f $HOMEDIR/$user/conf/web/*
  56. sed -i "/.*\/$user\/.*$WEB_SYSTEM.conf/d" $web_conf
  57. if [ ! -z "$PROXY_SYSTEM" ]; then
  58. sed -i "/.*\/$user\/.*$PROXY_SYSTEM.conf/d" $proxy_conf
  59. fi
  60. else
  61. # Clean web configs
  62. sed -i "/.*\/$user\/.*.conf/d" $web_conf
  63. if [ ! -z "$PROXY_SYSTEM" ]; then
  64. sed -i "/.*\/$user\/.*.conf/d" $proxy_conf
  65. fi
  66. # Renaming tmp config
  67. tmp_conf="$HOMEDIR/$user/conf/web/tmp_$WEB_SYSTEM.conf"
  68. conf="$HOMEDIR/$user/conf/web/$WEB_SYSTEM.conf"
  69. mv $tmp_conf $conf
  70. # Checking include
  71. web_include=$(grep "$conf" $web_conf )
  72. if [ -z "$web_include" ]; then
  73. echo "Include $conf" >> $web_conf
  74. fi
  75. # Checking SSL
  76. if [ "$ssl_change" = 'yes' ]; then
  77. tmp_conf="$HOMEDIR/$user/conf/web/tmp_s$WEB_SYSTEM.conf"
  78. conf="$HOMEDIR/$user/conf/web/s$WEB_SYSTEM.conf"
  79. mv $tmp_conf $conf
  80. fi
  81. ssl_include=$(grep "$conf" $web_conf )
  82. if [ -z "$ssl_include" ]; then
  83. echo "Include $conf" >> $web_conf
  84. fi
  85. # Checking proxy
  86. if [ ! -z "$PROXY_SYSTEM" ]; then
  87. if [ "$proxy_change" = 'yes' ]; then
  88. tmp_conf="$HOMEDIR/$user/conf/web/tmp_$PROXY_SYSTEM.conf"
  89. conf="$HOMEDIR/$user/conf/web/$PROXY_SYSTEM.conf"
  90. mv $tmp_conf $conf
  91. proxy_include=$(grep "$conf" $proxy_conf )
  92. if [ -z "$proxy_include" ]; then
  93. echo "include $conf;" >> $proxy_conf
  94. fi
  95. else
  96. conf="$HOMEDIR/$user/conf/web/$PROXY_SYSTEM.conf"
  97. sed -i "/.*\/$user\/.*$PROXY_SYSTEM.conf/d" $proxy_conf
  98. rm -f $HOMEDIR/$user/conf/web/$PROXY_SYSTEM.conf
  99. fi
  100. # Checking SSL proxy
  101. if [ "$proxy_change" = 'yes' ] && [ "$ssl_change" = 'yes' ]; then
  102. tmp_conf="$HOMEDIR/$user/conf/web/tmp_s$PROXY_SYSTEM.conf"
  103. conf="$HOMEDIR/$user/conf/web/s$PROXY_SYSTEM.conf"
  104. mv $tmp_conf $conf
  105. proxy_include=$(grep "$conf" $proxy_conf )
  106. if [ -z "$proxy_include" ]; then
  107. echo "include $conf;" >> $proxy_conf
  108. fi
  109. else
  110. conf="$HOMEDIR/$user/conf/web/s$PROXY_SYSTEM.conf"
  111. sed -i "/.*\/$user\/.*$PROXY_SYSTEM.conf/d" $proxy_conf
  112. rm -f $HOMEDIR/$user/conf/web/s$PROXY_SYSTEM.conf
  113. fi
  114. fi
  115. fi
  116. #----------------------------------------------------------#
  117. # Vesta #
  118. #----------------------------------------------------------#
  119. # Updating counters
  120. update_user_value "$user" '$SUSPENDED_WEB' "$suspended_web"
  121. update_user_value "$user" '$U_WEB_DOMAINS' "$user_domains"
  122. update_user_value "$user" '$U_WEB_SSL' "$user_ssl"
  123. update_user_value "$user" '$U_WEB_ALIASES' "$user_aliases"
  124. # Restart web server
  125. if [ "$restart" != 'no' ]; then
  126. $BIN/v-restart-web
  127. if [ $? -ne 0 ]; then
  128. exit E_RESTART
  129. fi
  130. $BIN/v-restart-proxy
  131. if [ $? -ne 0 ]; then
  132. exit E_RESTART
  133. fi
  134. fi
  135. # Logging
  136. log_event "$OK" "$EVENT"
  137. exit