v-update-user-stats 2.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. #!/bin/bash
  2. # info: update user statistics
  3. # options: user
  4. #
  5. # Function logs user parameters into statistics database.
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument defenition
  10. user=$1
  11. # Importing system enviroment as we run this script
  12. # mostly by cron wich not read it by itself
  13. source /etc/profile
  14. # Includes
  15. source $VESTA/conf/vesta.conf
  16. source $VESTA/func/main.sh
  17. source $VESTA/func/domain.sh
  18. #----------------------------------------------------------#
  19. # Verifications #
  20. #----------------------------------------------------------#
  21. check_args '0' "$#" 'user'
  22. if [ ! -z "$user" ]; then
  23. validate_format 'user'
  24. is_object_valid 'user' 'USER' "$user"
  25. fi
  26. #----------------------------------------------------------#
  27. # Action #
  28. #----------------------------------------------------------#
  29. # Creating user_list
  30. if [ -z "$user" ]; then
  31. user_list=$(ls $VESTA/data/users)
  32. else
  33. user_list="$user"
  34. fi
  35. # Updating user stats
  36. for user in $user_list; do
  37. USER_DATA=$VESTA/data/users/$user
  38. source $USER_DATA/user.conf
  39. DATE=$(date -d "$(date +'%m/01' -d "+ 1 month") -1day" +%F)
  40. # Compiling report string
  41. s="DATE='$DATE' TIME='$TIME' PACKAGE='$PACKAGE' IP_OWNED='$IP_OWNED'"
  42. s="$s DISK_QUOTA='$DISK_QUOTA' U_DISK='$U_DISK' U_DISK_DIRS='$U_DISK_DIRS'"
  43. s="$s U_DISK_WEB='$U_DISK_WEB' U_DISK_MAIL='$U_DISK_MAIL'"
  44. s="$s U_DISK_DB='$U_DISK_DB' BANDWIDTH='$BANDWIDTH'"
  45. s="$s U_BANDWIDTH='$U_BANDWIDTH' U_WEB_DOMAINS='$U_WEB_DOMAINS'"
  46. s="$s U_WEB_SSL='$U_WEB_SSL' U_WEB_ALIASES='$U_WEB_ALIASES'"
  47. s="$s U_DNS_DOMAINS='$U_DNS_DOMAINS' U_DNS_RECORDS='$U_DNS_RECORDS'"
  48. s="$s U_MAIL_DOMAINS='$U_MAIL_DOMAINS' U_MAIL_DKIM='$U_MAIL_DKIM'"
  49. s="$s U_MAIL_ACCOUNTS='$U_MAIL_ACCOUNTS' U_DATABASES='$U_DATABASES'"
  50. s="$s U_CRON_JOBS='$U_CRON_JOBS' U_BACKUPS='$U_BACKUPS'"
  51. # Updating user stats log
  52. stats="$USER_DATA/stats.log"
  53. if [ -e "$stats" ]; then
  54. # Checking dublicates
  55. check_month=$(grep -n "DATE='$DATE'" $stats|cut -f 1 -d :)
  56. if [ -z "$check_month" ]; then
  57. # Updating as there no dublicates
  58. echo "$s" >> $stats
  59. chmod 660 $stats
  60. else
  61. # Replacing string with new data
  62. sed -i "$check_month s/.*/$s/" $stats
  63. fi
  64. else
  65. # Creating stats log
  66. echo "$s" >$stats
  67. chmod 660 $stats
  68. fi
  69. done
  70. #----------------------------------------------------------#
  71. # Vesta #
  72. #----------------------------------------------------------#
  73. # Logging
  74. log_event "$OK" "$EVENT"
  75. exit