v-add-user 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228
  1. #!/bin/bash
  2. # info: add system user
  3. # options: USER PASSWORD EMAIL [PACKAGE] [FNAME] [LNAME]
  4. #
  5. # The function creates new user account.
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument defenition
  10. user=$1
  11. password=$2
  12. email=$3
  13. package=${4-default}
  14. fname=$5
  15. lname=$6
  16. # Includes
  17. source $VESTA/func/main.sh
  18. source $VESTA/conf/vesta.conf
  19. # Hiding password
  20. A2='******'
  21. EVENT="$DATE $TIME $SCRIPT $A1 $A2 $A3 $A4 $A5 $A6 $A7 $A8 $A9"
  22. is_user_free() {
  23. check_sysuser=$(cut -f 1 -d : /etc/passwd | grep -w "$user" )
  24. if [ ! -z "$check_sysuser" ] || [ -e "$USER_DATA" ]; then
  25. echo "Error: user $user exist"
  26. log_event "$E_EXISTS" "$EVENT"
  27. exit $E_EXISTS
  28. fi
  29. }
  30. #----------------------------------------------------------#
  31. # Verifications #
  32. #----------------------------------------------------------#
  33. check_args '3' "$#" 'USER PASSWORD EMAIL [PACKAGE] [FNAME] [LNAME]'
  34. validate_format 'user' 'password' 'email' 'package'
  35. if [ ! -z "$fname" ]; then
  36. validate_format 'fname' 'lname'
  37. fi
  38. is_user_free "$user"
  39. is_package_valid
  40. #----------------------------------------------------------#
  41. # Action #
  42. #----------------------------------------------------------#
  43. # Parsing package data
  44. pkg_data=$(cat $VESTA/data/packages/$package.pkg |grep -v TIME |grep -v DATE)
  45. # Checking shell
  46. shell_conf=$(echo "$pkg_data" | grep 'SHELL' | cut -f 2 -d \')
  47. shell=$(grep -w "$shell_conf" /etc/shells |head -n1)
  48. # Adding user
  49. /usr/sbin/useradd "$user" -s "$shell" -c "$email" -m -d "$HOMEDIR/$user"
  50. if [ $? -ne 0 ]; then
  51. echo "Error: user creation failed"
  52. log_event "$E_INVALID" "$EVENT"
  53. exit $E_INVALID
  54. fi
  55. # Adding password
  56. echo "$user:$password" | /usr/sbin/chpasswd
  57. # Building directory tree
  58. mkdir $HOMEDIR/$user/conf
  59. if [ ! -z "$WEB_SYSTEM" ]; then
  60. mkdir $HOMEDIR/$user/conf/web
  61. mkdir $HOMEDIR/$user/web
  62. mkdir $HOMEDIR/$user/tmp
  63. chmod 751 $HOMEDIR/$user/conf/web
  64. chmod 751 $HOMEDIR/$user/web
  65. chmod 771 $HOMEDIR/$user/tmp
  66. chown $user:$user $HOMEDIR/$user/web
  67. chown $user:$user $HOMEDIR/$user/tmp
  68. fi
  69. if [ ! -z "$MAIL_SYSTEM" ]; then
  70. mkdir $HOMEDIR/$user/conf/mail
  71. mkdir $HOMEDIR/$user/mail
  72. chmod 751 $HOMEDIR/$user/mail
  73. chmod 751 $HOMEDIR/$user/conf/mail
  74. fi
  75. if [ ! -z "$DNS_SYSTEM" ]; then
  76. mkdir $HOMEDIR/$user/conf/dns
  77. chmod 751 $HOMEDIR/$user/conf/dns
  78. fi
  79. # Set permissions
  80. chmod a+x $HOMEDIR/$user
  81. chattr +i $HOMEDIR/$user/conf
  82. #----------------------------------------------------------#
  83. # Vesta #
  84. #----------------------------------------------------------#
  85. # Adding user dir
  86. mkdir $USER_DATA
  87. chmod 770 $USER_DATA
  88. # Creating configuration files and pipes
  89. touch $USER_DATA/backup.conf
  90. chmod 660 $USER_DATA/backup.conf
  91. touch $USER_DATA/history.log
  92. chmod 660 $USER_DATA/history.log
  93. touch $USER_DATA/stats.log
  94. chmod 660 $USER_DATA/stats.log
  95. echo "$BIN/v-update-user-disk $user" >> $VESTA/data/queue/disk.pipe
  96. if [ ! -z "$WEB_SYSTEM" ]; then
  97. mkdir $USER_DATA/ssl
  98. chmod 770 $USER_DATA/ssl
  99. touch $USER_DATA/web.conf
  100. chmod 660 $USER_DATA/web.conf
  101. echo "$BIN/v-update-web-domains-traff $user" \
  102. >> $VESTA/data/queue/traffic.pipe
  103. echo "$BIN/v-update-web-domains-disk $user" >> $VESTA/data/queue/disk.pipe
  104. fi
  105. if [ ! -z "$DNS_SYSTEM" ]; then
  106. mkdir $USER_DATA/dns
  107. chmod 770 $USER_DATA/dns
  108. touch $USER_DATA/dns.conf
  109. chmod 660 $USER_DATA/dns.conf
  110. fi
  111. if [ ! -z "$MAIL_SYSTEM" ]; then
  112. mkdir $USER_DATA/mail
  113. chmod 770 $USER_DATA/mail
  114. touch $USER_DATA/mail.conf
  115. chmod 660 $USER_DATA/mail.conf
  116. echo "$BIN/v-update-mail-domains-disk $user" >> $VESTA/data/queue/disk.pipe
  117. fi
  118. if [ ! -z "$DB_SYSTEM" ]; then
  119. touch $USER_DATA/db.conf
  120. chmod 660 $USER_DATA/db.conf
  121. echo "$BIN/v-update-databases-disk $user" >> $VESTA/data/queue/disk.pipe
  122. fi
  123. if [ ! -z "$CRON_SYSTEM" ]; then
  124. touch $USER_DATA/cron.conf
  125. chmod 660 $USER_DATA/cron.conf
  126. fi
  127. # Filling user config
  128. if [ "$user" != 'admin' ]; then
  129. ip_avail=$($BIN/v-list-user-ips admin plain |grep -w shared|wc -l)
  130. u_users=0
  131. else
  132. ip_avail=0
  133. u_users=1
  134. fi
  135. echo "FNAME='$fname'
  136. LNAME='$lname'
  137. PACKAGE='$package'
  138. $pkg_data
  139. CONTACT='$email'
  140. CRON_REPORTS='yes'
  141. MD5='$(awk -v user=$user -F : 'user == $1 {print $2}' /etc/shadow)'
  142. RKEY='$(gen_password)'
  143. SUSPENDED='no'
  144. SUSPENDED_USERS='0'
  145. SUSPENDED_WEB='0'
  146. SUSPENDED_DNS='0'
  147. SUSPENDED_MAIL='0'
  148. SUSPENDED_DB='0'
  149. SUSPENDED_CRON='0'
  150. IP_AVAIL='$ip_avail'
  151. IP_OWNED='0'
  152. U_USERS='$u_users'
  153. U_DISK='0'
  154. U_DISK_DIRS='0'
  155. U_DISK_WEB='0'
  156. U_DISK_MAIL='0'
  157. U_DISK_DB='0'
  158. U_BANDWIDTH='0'
  159. U_WEB_DOMAINS='0'
  160. U_WEB_SSL='0'
  161. U_WEB_ALIASES='0'
  162. U_DNS_DOMAINS='0'
  163. U_DNS_RECORDS='0'
  164. U_MAIL_DOMAINS='0'
  165. U_MAIL_DKIM='0'
  166. U_MAIL_ACCOUNTS='0'
  167. U_DATABASES='0'
  168. U_CRON_JOBS='0'
  169. U_BACKUPS='0'
  170. LANGUAGE=''
  171. TIME='$TIME'
  172. DATE='$DATE'" > $USER_DATA/user.conf
  173. chmod 660 $USER_DATA/user.conf
  174. # Updating quota
  175. if [ "$DISK_QUOTA" = 'yes' ]; then
  176. echo "Setting quota"
  177. $BIN/v-update-user-quota "$user"
  178. fi
  179. # Updating admin counter
  180. if [ "$user" != 'admin' ]; then
  181. increase_user_value 'admin' '$U_USERS'
  182. fi
  183. # Run template trigger
  184. if [ -x "$VESTA/data/packages/$package.sh" ]; then
  185. $VESTA/data/packages/$package.sh "$user" "$email" "$fname" "$lname"
  186. fi
  187. # Logging
  188. log_history "added system user $user" '' 'admin'
  189. log_event "$OK" "$EVENT"
  190. exit