v_add_sys_user 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167
  1. #!/bin/bash
  2. # info: adding system user
  3. #----------------------------------------------------------#
  4. # Variable&Function #
  5. #----------------------------------------------------------#
  6. # Argument defenition
  7. user=$1
  8. password=$2
  9. email=$3
  10. package=${4-default}
  11. fname=$5
  12. lname=$6
  13. # Importing variables
  14. source $VESTA/conf/vars.conf
  15. source $V_CONF/vesta.conf
  16. source $V_FUNC/shared.func
  17. is_user_free() {
  18. # Parsing domain values
  19. check_sysuser=$(cut -f 1 -d : /etc/passwd | grep -w "$user" )
  20. # Checking result
  21. if [ ! -z "$check_sysuser" ] || [ -e "$V_USERS/$user" ]; then
  22. echo "Error: user $user exist"
  23. log_event 'debug' "$E_EXISTS $V_EVENT"
  24. exit $E_EXISTS
  25. fi
  26. }
  27. #----------------------------------------------------------#
  28. # Verifications #
  29. #----------------------------------------------------------#
  30. # Checking arg number
  31. check_args '3' "$#" 'user password email [package] [fname] [lname]'
  32. # Checking argument format
  33. format_validation 'user' 'password' 'email' 'package' 'fname' 'lname'
  34. # Checking user
  35. is_user_free "$user"
  36. # Checking package
  37. is_package_valid "$package"
  38. #----------------------------------------------------------#
  39. # Action #
  40. #----------------------------------------------------------#
  41. # Parsing package data
  42. package_data=$(cat $V_PKG/$package.pkg)
  43. # Checking shell
  44. shell_conf=$(echo "$package_data"|grep 'SHELL'|cut -f 2 -d \')
  45. case $shell_conf in
  46. nologin) shell='/sbin/nologin' ;;
  47. bash) shell='/bin/bash' ;;
  48. *) shell='/sbin/nologin' ;;
  49. esac
  50. # Adding user
  51. /usr/sbin/adduser "$user" -s "$shell" -c "$email" -m -d "$V_HOME/$user"
  52. # Adding password
  53. echo "$password" | /usr/bin/passwd "$user" --stdin >/dev/null 2>&1
  54. # Building directory tree
  55. if [ ! -z "$BACKUP_SYSTEM" ] && [ "$BACKUP_SYSTEM" != 'no' ]; then
  56. mkdir $V_HOME/$user/backup
  57. chmod 751 $V_HOME/$user/backup
  58. fi
  59. if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'no' ]; then
  60. mkdir $V_HOME/$user/conf
  61. mkdir $V_HOME/$user/web
  62. mkdir $V_HOME/$user/tmp
  63. chmod 751 $V_HOME/$user/conf
  64. chmod 751 $V_HOME/$user/web
  65. chmod 777 $V_HOME/$user/tmp
  66. chown $user:$user $V_HOME/$user/web
  67. fi
  68. if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'no' ]; then
  69. mkdir $V_HOME/$user/mail
  70. chmod 751 $V_HOME/$user/mail
  71. fi
  72. # Set permissions
  73. chmod -R a+x $V_HOME/$user
  74. # Checking quota
  75. if [ ! -z "$DISK_QUOTA" ] && [ "$DISK_QUOTA" != 'no' ]; then
  76. DISK_QUOTA=$(echo "$package_data"|grep 'DISK_QUOTA' | cut -f 2 -d \')
  77. set_quota "$user" "$DISK_QUOTA"
  78. fi
  79. #----------------------------------------------------------#
  80. # Vesta #
  81. #----------------------------------------------------------#
  82. # Adding user dir
  83. mkdir $V_USERS/$user
  84. # Creating configuration files and pipes
  85. touch $V_USERS/$user/user.conf
  86. echo "v_upd_sys_user_disk $user" >> $V_QUEUE/disk.pipe
  87. if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'no' ]; then
  88. mkdir $V_USERS/$user/ssl
  89. touch $V_USERS/$user/web.conf
  90. echo "$V_BIN/v_upd_web_domains_traff $user" >> $V_QUEUE/traffic.pipe
  91. echo "v_upd_web_domains_disk $user" >> $V_QUEUE/disk.pipe
  92. fi
  93. if [ ! -z "$DNS_SYSTEM" ] && [ "$DNS_SYSTEM" != 'no' ]; then
  94. touch $V_USERS/$user/dns.conf
  95. mkdir $V_USERS/$user/dns
  96. fi
  97. if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'no' ]; then
  98. touch $V_USERS/$user/mail_domains.conf
  99. touch $V_USERS/$user/mail_boxes.conf
  100. echo "v_upd_mail_domains_disk $user" >> $V_QUEUE/disk.pipe
  101. fi
  102. if [ ! -z "$DB_SYSTEM" ] && [ "$DB_SYSTEM" != 'no' ]; then
  103. touch $V_USERS/$user/db.conf
  104. echo "v_upd_db_bases_disk $user" >> $V_QUEUE/disk.pipe
  105. fi
  106. if [ ! -z "$CRON_SYSTEM" ] && [ "$CRON_SYSTEM" != 'no' ]; then
  107. touch $V_USERS/$user/cron.conf
  108. fi
  109. # Filling user config
  110. echo "FNAME='$fname'
  111. LNAME='$lname'
  112. PACKAGE='$package'
  113. $package_data
  114. SUSPENDED='no'
  115. CONTACT='$email'
  116. REPORTS='yes'
  117. RKEY='$(gen_password)'
  118. IP_OWNED='0'
  119. U_DIR_DISK='0'
  120. U_DISK='0'
  121. U_BANDWIDTH='0'
  122. U_WEB_DOMAINS='0'
  123. U_WEB_SSL='0'
  124. U_DNS_DOMAINS='0'
  125. U_DATABASES='0'
  126. U_MAIL_DOMAINS='0'
  127. DATE='$V_DATE'" > $V_USERS/$user/user.conf
  128. # Hiding password
  129. V_EVENT="$V_DATE $V_SCRIPT $user ***** $email $package $fname $lname"
  130. # Logging
  131. log_event 'system' "$V_EVENT"
  132. exit