v_add_sys_user 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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. role="$4"
  11. owner="${5-vesta}"
  12. package="${6-default}"
  13. ns1=$7
  14. ns2=$8
  15. # Importing variables
  16. source $VESTA/conf/vars.conf
  17. source $V_FUNC/shared_func.sh
  18. #----------------------------------------------------------#
  19. # Verifications #
  20. #----------------------------------------------------------#
  21. # Checking arg number
  22. check_args '5' "$#" 'user password email role owner [package] [ns1] [ns2]'
  23. # Checking argument format
  24. format_validation 'user' 'password' 'email' 'role' 'owner' 'package'
  25. format_validation 'ns1' 'ns2'
  26. # Checking user
  27. is_user_free "$user"
  28. # Checking 'vesta' user creation
  29. if [ "$user" != 'vesta' ]; then
  30. # Checking owner
  31. is_user_valid "$owner"
  32. # Checking owner role
  33. is_user_privileged "$owner"
  34. # Checking owner permission
  35. is_user_privileged "$owner" "$role"
  36. # Checking package
  37. is_package_valid "$package"
  38. fi
  39. #----------------------------------------------------------#
  40. # Action #
  41. #----------------------------------------------------------#
  42. # Importing main config
  43. source $V_CONF/vesta.conf
  44. # Parsing package data
  45. package_data=$(cat $V_PKG/$package.pkg)
  46. # Checking shell
  47. shell_conf=$(echo "$package_data"|grep 'SHELL'|cut -f 2 -d \')
  48. case $shell_conf in
  49. nologin) shell='/sbin/nologin' ;;
  50. bash) shell='/bin/bash' ;;
  51. *) shell='/sbin/nologin' ;;
  52. esac
  53. # Adding user
  54. /usr/sbin/adduser "$user" -s "$shell" -c "$email" -m -d "$V_HOME/$user"
  55. # Adding password
  56. echo "$password" | /usr/bin/passwd "$user" --stdin >/dev/null 2>&1
  57. # Building directory tree
  58. if [ ! -z "$BACKUP_SYSTEM" ] && [ "$BACKUP_SYSTEM" != 'no' ]; then
  59. mkdir $V_HOME/$user/backup
  60. chmod 751 $V_HOME/$user/backup
  61. fi
  62. if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'no' ]; then
  63. mkdir $V_HOME/$user/conf
  64. mkdir $V_HOME/$user/domains
  65. mkdir $V_HOME/$user/tmp
  66. chmod 751 $V_HOME/$user/conf
  67. chmod 751 $V_HOME/$user/domains
  68. chmod 777 $V_HOME/$user/tmp
  69. chown $user:$user $V_HOME/$user/domains
  70. fi
  71. if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'no' ]; then
  72. mkdir $V_HOME/$user/mail
  73. chmod 751 $V_HOME/$user/mail
  74. fi
  75. # Set permissions
  76. chmod -R a+x $V_HOME/$user
  77. # Checking quota
  78. if [ ! -z "$DISK_QUOTA" ] && [ "$DISK_QUOTA" != 'off' ]; then
  79. DISK_QUOTA=$(echo "$package_data"|grep 'DISK_QUOTA' | cut -f 2 -d \')
  80. set_quota "$user" "$DISK_QUOTA"
  81. fi
  82. #----------------------------------------------------------#
  83. # Vesta #
  84. #----------------------------------------------------------#
  85. # Adding user dir
  86. mkdir $V_USERS/$user
  87. # Creating configuration files and pipes
  88. touch $V_USERS/$user/user.conf
  89. echo "v_upd_sys_user_disk $user" >> $V_QUEUE/disk.pipe
  90. if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'no' ]; then
  91. mkdir $V_USERS/$user/cert
  92. touch $V_USERS/$user/web_domains.conf
  93. echo "v_upd_web_domains_traff $user" >> $V_QUEUE/traffic.pipe
  94. echo "v_upd_web_domains_disk $user" >> $V_QUEUE/disk.pipe
  95. fi
  96. if [ ! -z "$DNS_SYSTEM" ] && [ "$DNS_SYSTEM" != 'no' ]; then
  97. touch $V_USERS/$user/dns.conf
  98. mkdir $V_USERS/$user/zones
  99. fi
  100. if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'no' ]; then
  101. touch $V_USERS/$user/mail_domains.conf
  102. touch $V_USERS/$user/mail_boxes.conf
  103. echo "v_upd_mail_domains_disk $user" >> $V_QUEUE/disk.pipe
  104. fi
  105. if [ ! -z "$DB_SYSTEM" ] && [ "$DB_SYSTEM" != 'no' ]; then
  106. touch $V_USERS/$user/db.conf
  107. echo "v_upd_db_bases_disk $user" >> $V_QUEUE/disk.pipe
  108. fi
  109. if [ ! -z "$CRON_SYSTEM" ] && [ "$CRON_SYSTEM" != 'no' ]; then
  110. touch $V_USERS/$user/crontab.conf
  111. fi
  112. if [ ! -z "$BACKUP_SYSTEM" ] && [ "$BACKUP_SYSTEM" != 'no' ]; then
  113. echo "v_backup_sys_user $user" >> $V_QUEUE/backup.pipe
  114. fi
  115. # Rewriting nameservers
  116. if [ ! -z "$ns1" ]; then
  117. package_data=$(echo "$package_data" | sed -e "s/NS1=.*$/NS1='$ns1'/g")
  118. fi
  119. if [ ! -z "$ns2" ]; then
  120. package_data=$(echo "$package_data" | sed -e "s/NS2=.*$/NS2='$ns2'/g")
  121. fi
  122. # Filling user config
  123. echo "PACKAGE='$package'
  124. $package_data
  125. SUSPENDED='no'
  126. OWNER='$owner'
  127. ROLE='$role'
  128. CONTACT='$email'
  129. REPORTS='yes'
  130. IP_OWNED='0'
  131. U_CHILDS='0'
  132. U_DISK='0'
  133. U_BANDWIDTH='0'
  134. U_WEB_DOMAINS='0'
  135. U_WEB_SSL='0'
  136. U_DNS_DOMAINS='0'
  137. U_DATABASES='0'
  138. U_MAIL_DOMAINS='0'
  139. DATE='$V_DATE'" > $V_USERS/$user/user.conf
  140. # Filling owner config
  141. ROLE=$(echo "$role" | tr "[:lower:]" "[:upper:]")
  142. if [ "$user" != 'vesta' ]; then
  143. echo "$ROLE='$user'" >> $V_USERS/$owner/reseller.conf
  144. increase_user_value "$owner" 'U_CHILDS'
  145. fi
  146. # Hiding password
  147. V_EVENT=$(echo $V_EVENT | sed -e "s/$password/xxxxxx/g")
  148. # Logging
  149. log_event 'system' "$V_EVENT"
  150. exit $OK