v-backup-user 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683
  1. #!/bin/bash
  2. # info: backup system user with all its objects
  3. # options: USER NOTIFY
  4. #
  5. # The call is used for backing up user with all its domains and databases.
  6. #----------------------------------------------------------#
  7. # Variable&Function #
  8. #----------------------------------------------------------#
  9. # Argument defenition
  10. user=$1
  11. notify=${2-no}
  12. # Includes
  13. source $VESTA/conf/vesta.conf
  14. source $VESTA/func/main.sh
  15. source $VESTA/func/domain.sh
  16. source $VESTA/func/db.sh
  17. #----------------------------------------------------------#
  18. # Verifications #
  19. #----------------------------------------------------------#
  20. check_args '1' "$#" 'USER [NOTIFY]'
  21. validate_format 'user'
  22. is_system_enabled "$BACKUP_SYSTEM"
  23. is_object_valid 'user' 'USER' "$user"
  24. is_object_unsuspended 'user' 'USER' "$user"
  25. is_backup_enabled
  26. #----------------------------------------------------------#
  27. # Action #
  28. #----------------------------------------------------------#
  29. # Set backup directory if undefined
  30. if [ -z "$BACKUP" ]; then
  31. BACKUP=/home/backup/
  32. fi
  33. mkdir -p $BACKUP
  34. # Get current time
  35. start_time=$(date '+%s')
  36. # Set notification email and subject
  37. if [ "$notify" != 'no' ]; then
  38. subj="$user → backup failed"
  39. email=$(get_user_value '$CONTACT')
  40. else
  41. subj="$user → backup failed"
  42. email=$(grep CONTACT $VESTA/data/users/admin/user.conf | cut -f 2 -d \')
  43. fi
  44. if [ -e "$VESTA/web/inc/mail-wrapper.php" ]; then
  45. send_mail="$VESTA/web/inc/mail-wrapper.php"
  46. else
  47. send_mail=$(which mail)
  48. fi
  49. # Check load average
  50. la=$(cat /proc/loadavg | cut -f 1 -d ' ' | cut -f 1 -d '.')
  51. i=0
  52. while [ "$la" -ge "$BACKUP_LA_LIMIT" ]; do
  53. echo "$(date "+%F %T") Load Average $la"
  54. echo
  55. sleep 60
  56. if [ "$i" -ge "15" ]; then
  57. echo "LoadAverage $i is above threshold" | $send_mail -s "$subj" $email
  58. echo "Error: LA is too high"
  59. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  60. log_event "$E_LA" "$EVENT"
  61. exit $E_LA
  62. fi
  63. (( ++i))
  64. done
  65. # Creating temporary directory
  66. tmpdir=$(mktemp -p $BACKUP -d)
  67. if [ "$?" -ne 0 ]; then
  68. echo "Can't create tmp dir $tmpdir" | $send_mail -s "$subj" $email
  69. echo "Error: can't create tmp dir"
  70. log_event "$E_NOTEXIST" "$EVENT"
  71. exit $E_NOTEXIST
  72. fi
  73. # Backingup system configs
  74. echo -e "-- SYSTEM --"
  75. msg="-- SYSTEM --"
  76. mkdir $tmpdir/vesta
  77. echo -e "$(date "+%F %T") $user.conf"
  78. msg="$msg\n$(date "+%F %T") $user.conf"
  79. cp -r $USER_DATA/user.conf $tmpdir/vesta/
  80. if [ -e "$USER_DATA/stats.log" ]; then
  81. echo -e "$(date "+%F %T") stats.log"
  82. msg="$msg\n$(date "+%F %T") stats.log"
  83. cp -r $USER_DATA/stats.log $tmpdir/vesta/
  84. fi
  85. if [ -e "$USER_DATA/history.log" ]; then
  86. echo -e "$(date "+%F %T") history.log"
  87. msg="$msg\n$(date "+%F %T") history.log"
  88. cp -r $USER_DATA/history.log $tmpdir/vesta/
  89. fi
  90. if [ -e "$USER_DATA/backup.excludes" ]; then
  91. echo -e "$(date "+%F %T") backup.excludes"
  92. msg="$msg\n$(date "+%F %T") backup.excludes"
  93. cp -r $USER_DATA/backup.excludes $tmpdir/vesta/
  94. fi
  95. # Backup PAM
  96. mkdir $tmpdir/pam
  97. echo -e "$(date "+%F %T") pam"
  98. msg="$msg\n$(date "+%F %T") pam"
  99. grep "^$user:" /etc/passwd > $tmpdir/pam/passwd
  100. grep "^$user:" /etc/shadow > $tmpdir/pam/shadow
  101. grep "^$user:" /etc/group > $tmpdir/pam/group
  102. echo
  103. msg="$msg\n"
  104. # Parsing excludes
  105. OLD_IFS="$IFS"
  106. IFS=$'\n'
  107. if [ -e "$USER_DATA/backup.excludes" ]; then
  108. for exclude in $(cat $USER_DATA/backup.excludes); do
  109. eval ${exclude%%=*}=${exclude#*=}
  110. done
  111. fi
  112. IFS="$OLD_IFS"
  113. # WEB domains
  114. if [ ! -z "$WEB_SYSTEM" ] && [ "$WEB_SYSTEM" != 'no' ] && [ "$WEB" != '*' ]
  115. then
  116. echo "-- WEB --"
  117. msg="$msg\n-- WEB --"
  118. mkdir $tmpdir/web/
  119. # Parsing unsuspeneded domains
  120. conf="$USER_DATA/web.conf"
  121. for domain in $(search_objects 'web' 'SUSPENDED' "*" 'DOMAIN'); do
  122. check_exl=$(echo "$WEB"|grep -w $domain)
  123. if [ -z "$check_exl" ]; then
  124. web_list="$web_list $domain"
  125. fi
  126. done
  127. web_list=$(echo "$web_list" | sed -e "s/ */\ /g" -e "s/^ //")
  128. i=0
  129. for domain in $web_list; do
  130. ((i ++))
  131. echo -e "$(date "+%F %T") $domain"
  132. msg="$msg\n$(date "+%F %T") $domain"
  133. mkdir -p $tmpdir/web/$domain/conf
  134. mkdir -p $tmpdir/web/$domain/vesta
  135. # Defining domain variables
  136. domain_idn=$(idn -t --quiet -a "$domain")
  137. get_domain_values 'web'
  138. # Creating web.config
  139. cd $tmpdir/web/$domain/
  140. conf="$USER_DATA/web.conf"
  141. grep "DOMAIN='$domain'" $conf > vesta/web.conf
  142. # WEB config
  143. tpl_file="$WEBTPL/$WEB_SYSTEM/$TPL.tpl"
  144. conf="$HOMEDIR/$user/conf/web/$WEB_SYSTEM.conf"
  145. get_web_config_brds
  146. sed -n "$top_line,$bottom_line p" $conf > conf/$WEB_SYSTEM.conf
  147. # SSL check
  148. if [ "$SSL" = 'yes' ]; then
  149. tpl_file="$WEBTPL/$WEB_SYSTEM/$TPL.stpl"
  150. conf="$HOMEDIR/$user/conf/web/s$WEB_SYSTEM.conf"
  151. get_web_config_brds
  152. sed -n "$top_line,$bottom_line p" $conf > conf/s$WEB_SYSTEM.conf
  153. fi
  154. # Proxy config
  155. if [ ! -z "$PROXY" ]; then
  156. tpl_file="$WEBTPL/$PROXY_SYSTEM/$PROXY.tpl"
  157. conf="$HOMEDIR/$user/conf/web/$PROXY_SYSTEM.conf"
  158. get_web_config_brds
  159. sed -n "$top_line,$bottom_line p" $conf > conf/$PROXY_SYSTEM.conf
  160. # SSL proxy config
  161. if [ ! -z "$PROXY" ] && [ "$SSL" = 'yes' ] ; then
  162. tpl_file="$WEBTPL/$PROXY_SYSTEM/$PROXY.stpl"
  163. conf="$HOMEDIR/$user/conf/web/s$PROXY_SYSTEM.conf"
  164. get_web_config_brds
  165. sed -n "$top_line,$bottom_line p" $conf > conf/s$PROXY_SYSTEM.conf
  166. fi
  167. fi
  168. # Suplemental configs
  169. for sconfig in $(ls $HOMEDIR/$user/conf/web/|grep ".$domain.conf"); do
  170. cp $HOMEDIR/$user/conf/web/$sconfig conf/
  171. done
  172. # SSL Certificates
  173. if [ "$SSL" = 'yes' ] ; then
  174. cp $HOMEDIR/$user/conf/web/ssl.$domain.* conf/
  175. cp $USER_DATA/ssl/$domain.* vesta/
  176. fi
  177. # Packing data folders
  178. cd $HOMEDIR/$user/web/$domain
  179. domain_direcotries=$(ls |grep -v logs)
  180. tar -cpf $tmpdir/web/$domain/domain_data.tar $domain_direcotries
  181. if [ ! -z "$BACKUP_GZIP" ]; then
  182. gzip -$BACKUP_GZIP $tmpdir/web/$domain/domain_data.tar
  183. fi
  184. done
  185. if [ "$i" -eq 1 ]; then
  186. echo -e "$(date "+%F %T") $i domain"
  187. msg="$msg\n$(date "+%F %T") $i domain"
  188. else
  189. echo -e "$(date "+%F %T") $i domains"
  190. msg="$msg\n$(date "+%F %T") $i domains"
  191. fi
  192. echo
  193. msg="$msg\n"
  194. fi
  195. # DNS domains
  196. if [ ! -z "$DNS_SYSTEM" ] && [ "$DNS_SYSTEM" != 'no' ] && [ "$DNS" != '*' ]
  197. then
  198. echo "-- DNS --"
  199. msg="$msg\n-- DNS --"
  200. mkdir $tmpdir/dns/
  201. # Parsing unsuspeneded domains
  202. for domain in $(search_objects 'dns' 'SUSPENDED' "*" 'DOMAIN'); do
  203. check_exl=$(echo "$DNS"|grep -w $domain)
  204. if [ -z "$check_exl" ]; then
  205. dns_list="$dns_list $domain"
  206. fi
  207. done
  208. dns_list=$(echo "$dns_list" | sed -e "s/ */\ /g" -e "s/^ //")
  209. i=0
  210. for domain in $dns_list; do
  211. ((i ++))
  212. echo -e "$(date "+%F %T") $domain"
  213. msg="$msg\n$(date "+%F %T") $domain"
  214. # Building directory tree
  215. mkdir -p $tmpdir/dns/$domain/conf
  216. mkdir -p $tmpdir/dns/$domain/vesta
  217. # Creating dns_domains config
  218. cd $tmpdir/dns/$domain/
  219. conf="$USER_DATA/dns.conf"
  220. grep "DOMAIN='$domain'" $conf > vesta/dns.conf
  221. # Backingup dns recods
  222. cp $USER_DATA/dns/$domain.conf vesta/$domain.conf
  223. cp $HOMEDIR/$user/conf/dns/$domain.db conf/$domain.db
  224. done
  225. if [ "$i" -eq 1 ]; then
  226. echo -e "$(date "+%F %T") $i domain"
  227. msg="$msg\n$(date "+%F %T") $i domain"
  228. else
  229. echo -e "$(date "+%F %T") $i domains"
  230. msg="$msg\n$(date "+%F %T") $i domains"
  231. fi
  232. echo
  233. msg="$msg\n"
  234. fi
  235. # Mail domains
  236. if [ ! -z "$MAIL_SYSTEM" ] && [ "$MAIL_SYSTEM" != 'no' ] && [ "$MAIL" != '*' ]
  237. then
  238. echo "-- MAIL --"
  239. msg="$msg\n-- MAIL --"
  240. mkdir $tmpdir/mail/
  241. # Parsing unsuspeneded domains
  242. conf="$USER_DATA/mail.conf"
  243. for domain in $(search_objects 'mail' 'SUSPENDED' "*" 'DOMAIN'); do
  244. check_exl=$(echo "$MAIL"|grep -w $domain)
  245. if [ -z "$check_exl" ]; then
  246. mail_list="$mail_list $domain"
  247. fi
  248. done
  249. mail_list=$(echo "$mail_list" | sed -e "s/ */\ /g" -e "s/^ //")
  250. i=0
  251. for domain in $mail_list; do
  252. ((i ++))
  253. echo -e "$(date "+%F %T") $domain"
  254. msg="$msg\n$(date "+%F %T") $domain"
  255. mkdir -p $tmpdir/mail/$domain/conf
  256. mkdir -p $tmpdir/mail/$domain/vesta
  257. domain_idn=$(idn -t --quiet -a "$domain")
  258. # Creating exim config
  259. cd $tmpdir/mail/$domain/
  260. cp $HOMEDIR/$user/conf/mail/$domain/* conf/
  261. # Creating vesta config
  262. conf="$USER_DATA/mail.conf"
  263. grep "DOMAIN='$domain'" $conf > vesta/mail.conf
  264. cp $USER_DATA/mail/$domain.* vesta/
  265. if [ ! -z "$(ls $USER_DATA/mail/|grep *@$domain)" ]; then
  266. cp $USER_DATA/mail/*@$domain.* vesta/
  267. fi
  268. # Packing mailboxes
  269. cd $HOMEDIR/$user/mail/$domain_idn
  270. accounts=$(ls)
  271. if [ ! -z "$accounts" ]; then
  272. tar -cpf $tmpdir/mail/$domain/accounts.tar $accounts
  273. fi
  274. if [ ! -z "$BACKUP_GZIP" ] && [ ! -z $accounts ]; then
  275. gzip -$BACKUP_GZIP $tmpdir/mail/$domain/accounts.tar
  276. fi
  277. done
  278. if [ "$i" -eq 1 ]; then
  279. echo -e "$(date "+%F %T") $i domain"
  280. msg="$msg\n$(date "+%F %T") $i domain"
  281. else
  282. echo -e "$(date "+%F %T") $i domains"
  283. msg="$msg\n$(date "+%F %T") $i domains"
  284. fi
  285. echo
  286. msg="$msg\n"
  287. fi
  288. # Databases
  289. if [ ! -z "$DB_SYSTEM" ] && [ "$DB_SYSTEM" != 'no' ] && [ "$DB" != '*' ]; then
  290. echo "-- DB --"
  291. msg="$msg\n-- DB --"
  292. mkdir $tmpdir/db/
  293. # Parsing unsuspeneded domains
  294. for database in $(search_objects 'db' 'SUSPENDED' "*" 'DB'); do
  295. check_exl=$(echo "$DB"|grep -w $database)
  296. if [ -z "$check_exl" ]; then
  297. db_list="$db_list $database"
  298. fi
  299. done
  300. db_list=$(echo "$db_list" | sed -e "s/ */\ /g" -e "s/^ //")
  301. i=0
  302. conf="$USER_DATA/db.conf"
  303. for database in $db_list; do
  304. ((i ++))
  305. get_database_values
  306. echo -e "$(date "+%F %T") $TYPE $database"
  307. msg="$msg\n$(date "+%F %T") $TYPE $database"
  308. mkdir -p $tmpdir/db/$database/conf
  309. mkdir -p $tmpdir/db/$database/vesta
  310. cd $tmpdir/db/$database/
  311. grep "DB='$database'" $conf > vesta/db.conf
  312. dump="$tmpdir/db/$database/$database.$TYPE.sql"
  313. grants="$tmpdir/db/$database/conf/$database.$TYPE.$DBUSER"
  314. case $TYPE in
  315. mysql) dump_mysql_database ;;
  316. pgsql) dump_pgsql_database ;;
  317. esac
  318. if [ ! -z "$BACKUP_GZIP" ]; then
  319. gzip -$BACKUP_GZIP $dump
  320. fi
  321. done
  322. if [ "$i" -eq 1 ]; then
  323. echo -e "$(date "+%F %T") $i database"
  324. msg="$msg\n$(date "+%F %T") $i database"
  325. else
  326. echo -e "$(date "+%F %T") $i databases"
  327. msg="$msg\n$(date "+%F %T") $i databases"
  328. fi
  329. echo
  330. msg="$msg\n"
  331. fi
  332. # Cron jobs
  333. if [ ! -z "$CRON_SYSTEM" ] && [ "$CRON_SYSTEM" != 'no' ] && [ "$CRON" != '*' ]
  334. then
  335. echo "-- CRON --"
  336. msg="$msg\n-- CRON --"
  337. mkdir $tmpdir/cron/
  338. # Backingup cron recods
  339. echo -e "$(date "+%F %T") cron.conf"
  340. msg="$msg\n$(date "+%F %T") cron.conf"
  341. cp $USER_DATA/cron.conf $tmpdir/cron/
  342. cron_record=$(wc -l $USER_DATA/cron.conf|cut -f 1 -d ' ')
  343. if [ -e "/var/spool/cron/$user" ]; then
  344. cron_list="$cron_record"
  345. cp /var/spool/cron/$user $tmpdir/cron/
  346. fi
  347. if [ "$cron_record" -eq 1 ]; then
  348. echo -e "$(date "+%F %T") $cron_record record"
  349. msg="$msg\n$(date "+%F %T") $cron_record record"
  350. else
  351. echo -e "$(date "+%F %T") $cron_record records"
  352. msg="$msg\n$(date "+%F %T") $cron_record records"
  353. fi
  354. echo
  355. msg="$msg\n"
  356. fi
  357. # User Directories
  358. echo "-- User Dir --"
  359. msg="$msg\n-- User Dir --"
  360. mkdir $tmpdir/user_dir
  361. user_dir=$(ls $HOMEDIR/$user | \
  362. grep -v conf | \
  363. grep -v web | \
  364. grep -v dns | \
  365. grep -v mail | \
  366. grep -v tmp)
  367. i=0
  368. for udir in $user_dir; do
  369. udir_list="$udir_list $udir"
  370. ((i ++))
  371. echo -e "$(date "+%F %T") $udir"
  372. msg="$msg\n$(date "+%F %T") $udir"
  373. cp -pr $HOMEDIR/$user/$udir $tmpdir/user_dir/
  374. cd $tmpdir/user_dir/
  375. tar -czpf $udir.tar.gz $udir
  376. rm -rf $udir
  377. done
  378. udir_list=$(echo "$udir_list" | sed -e "s/ */\ /g" -e "s/^ //")
  379. if [ "$i" -eq 1 ]; then
  380. echo -e "$(date "+%F %T") $i user directory"
  381. msg="$msg\n$(date "+%F %T") $i directory"
  382. else
  383. echo -e "$(date "+%F %T") $i directories"
  384. msg="$msg\n$(date "+%F %T") $i directories"
  385. fi
  386. echo
  387. msg="$msg\n"
  388. # Get backup size
  389. size="$(du -shm $tmpdir | cut -f 1)"
  390. # Get current time
  391. end_time=$(date '+%s')
  392. DATE=$(date +%F)
  393. TIME=$(date +%T)
  394. # Defining local storage function
  395. local_backup(){
  396. # Removing dublicate for this day
  397. if [ -e "$BACKUP/$user.$DATE.tar" ]; then
  398. deprecated="$DATE"
  399. echo -e "$(date "+%F %T") Deleted old backup: $user.$DATE.tar"
  400. msg="$msg\n$(date "+%F %T") Deleted old backup: $user.$DATE.tar"
  401. rm -f $BACKUP/$user.$DATE.tar
  402. fi
  403. # Checking retention
  404. backup_list=$(ls -lrt $BACKUP/ | awk '{print $9}' |grep "^$user\.")
  405. backups_count=$(echo "$backup_list" | wc -l)
  406. if [ "$BACKUPS" -le "$backups_count" ]; then
  407. backups_rm_number=$((backups_count - BACKUPS))
  408. (( ++backups_rm_number))
  409. for backup in $(echo "$backup_list" | head -n $backups_rm_number); do
  410. # Removing old backup
  411. backup_date=$(echo $backup | sed -e "s/$user.//" -e "s/.tar$//")
  412. deprecated="$deprecated $backup_date"
  413. echo -e "$(date "+%F %T") Deleted old backup: $backup_date"
  414. msg="$msg\n$(date "+%F %T") Deleted old backup: $backup_date"
  415. rm -f $BACKUP/$backup
  416. done
  417. fi
  418. # Checking disk space
  419. disk_usage=$(df $BACKUP |tail -n1 |tr ' ' '\n' |grep % |cut -f 1 -d %)
  420. if [ "$disk_usage" -ge "$BACKUP_DISK_LIMIT" ]; then
  421. rm -rf $tmpdir
  422. echo "Not enough disk space to run backup" |\
  423. $send_mail -s "$subj" $email
  424. echo "Error: Not enough disk space"
  425. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  426. log_event "$E_DISK" "$EVENT"
  427. exit $E_DISK
  428. fi
  429. # Creating final tarball
  430. cd $tmpdir
  431. tar -cf $BACKUP/$user.$DATE.tar .
  432. chmod 640 $BACKUP/$user.$DATE.tar
  433. chown admin:$user $BACKUP/$user.$DATE.tar
  434. localbackup='yes'
  435. echo -e "$(date "+%F %T") Archived: $BACKUP/$user.$DATE.tar"
  436. msg="$msg\n$(date "+%F %T") Archived: $BACKUP/$user.$DATE.tar"
  437. U_BACKUPS=$(ls $BACKUP/ | grep "^$user." | wc -l)
  438. update_user_value "$user" '$U_BACKUPS' "$U_BACKUPS"
  439. }
  440. # Defining ftp command function
  441. ftpc() {
  442. ftp -n $HOST $PORT <<EOF
  443. quote USER $USERNAME
  444. quote PASS $PASSWORD
  445. binary
  446. $1
  447. $2
  448. $3
  449. quit
  450. EOF
  451. }
  452. # Defining ftp storage function
  453. ftp_backup() {
  454. # Checking config
  455. if [ ! -e "$VESTA/conf/ftp.backup.conf" ]; then
  456. ftp_conf_error="Can't open $VESTA/conf/ftp.backup.conf"
  457. echo "$ftp_conf_error" | $send_mail -s "$subj" $email
  458. echo "Error: $VESTA/conf/ftp.backup.conf does not exist"
  459. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  460. log_event "$E_NOTEXIST" "$EVENT"
  461. exit $E_NOTEXIST
  462. fi
  463. # Parse config
  464. source $VESTA/conf/ftp.backup.conf
  465. # Set default port
  466. if [ -z "$(grep 'PORT=' $VESTA/conf/ftp.backup.conf)" ]; then
  467. PORT='21'
  468. fi
  469. # Checking variables
  470. if [ -z "$HOST" ] || [ -z "$USERNAME" ] || [ -z "$PASSWORD" ]; then
  471. rm -rf $tmpdir
  472. echo "Can't parse ftp backup configuration" |\
  473. $send_mail -s "$subj" $email
  474. echo "Error: Parsing error"
  475. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  476. log_event "$E_PARSING" "$EVENT"
  477. exit $E_PARSING
  478. fi
  479. # Debug info
  480. echo -e "$(date "+%F %T") FTP ftp://$HOST$BPATH/$user.$DATE.tar"
  481. # Checking ftp connection
  482. if [ ! -z "$(ftpc)" ]; then
  483. rm -rf $tmpdir
  484. echo "Can't login to ftp://$USERNAME@$HOST" |\
  485. $send_mail -s "$subj" $email
  486. echo "Error: can't login to ftp ftp://$USERNAME@$HOST"
  487. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  488. log_event "$E_FTP" "$EVENT"
  489. exit $E_FTP
  490. fi
  491. # Check ftp permissions
  492. ftpc "mkdir $BPATH" > /dev/null 2>&1
  493. ftmpdir=$(mktemp -u -p "$BPATH")
  494. ftp_result=$(ftpc "mkdir $ftmpdir" "rm $ftmpdir")
  495. if [ ! -z "$ftp_result" ] ; then
  496. rm -rf $tmpdir
  497. echo "Can't create ftp backup folder" |\
  498. $send_mail -s "$subj" $email
  499. echo "Error: cant's create ftp folder"
  500. sed -i "/ $user /d" $VESTA/data/queue/backup.pipe
  501. log_event "$E_FTP" "$EVENT"
  502. exit $E_FTP
  503. fi
  504. # Checking retention
  505. backup_list=$(ftpc "cd $BPATH" "ls" |awk '{print $9}' |grep "^$user\.")
  506. backups_count=$(echo "$backup_list" | wc -l)
  507. if [ "$backups_count" -ge "$BACKUPS" ]; then
  508. backups_rm_number=$((backups_count - BACKUPS + 1))
  509. for backup in $(echo "$backup_list" | head -n $backups_rm_number); do
  510. backup_date=$(echo $backup | sed -e "s/$user.//" -e "s/.tar$//")
  511. deprecated="$deprecated $backup"
  512. echo -e "$(date "+%F %T") Deleted old ftp backup: $backup_date"
  513. msg="$msg\n$(date "+%F %T") Deleted old ftp backup: $backup_date"
  514. ftpc "cd $BPATH" "delete $backup"
  515. done
  516. fi
  517. # Uploading backup archive
  518. if [ "$localbackup" = 'yes' ]; then
  519. cd $BACKUP
  520. ftpc "cd $BPATH" "put $user.$DATE.tar"
  521. else
  522. cd $tmpdir
  523. tar -cf $BACKUP/$user.$DATE.tar .
  524. cd $BACKUP/
  525. ftpc "cd $BPATH" "put $user.$DATE.tar"
  526. rm -f $user.$DATE.tar
  527. fi
  528. }
  529. echo "-- SUMMARY --"
  530. msg="$msg\n-- SUMMARY --"
  531. # Switching on backup system types
  532. for backup_type in $(echo -e "${BACKUP_SYSTEM//,/\n}"); do
  533. case $backup_type in
  534. local) local_backup ;;
  535. ftp) ftp_backup ;;
  536. esac
  537. done
  538. # Removing tmpdir
  539. cd /
  540. rm -rf $tmpdir
  541. # Calculation run time
  542. run_time=$((end_time - start_time))
  543. run_time=$((run_time / 60))
  544. current_time=$(date "+%T")
  545. if [ "$run_time" -lt 1 ]; then
  546. run_time=1
  547. fi
  548. min=miutes
  549. if [ "$run_time" -eq 1 ]; then
  550. min=minute
  551. fi
  552. echo "$(date "+%F %T") Size: $size Mb"
  553. msg="$msg\n$(date "+%F %T") Size: $size Mb"
  554. echo "$(date "+%F %T") RUNTIME: $run_time $min"
  555. msg="$msg\n$(date "+%F %T") RUNTIME: $run_time $min"
  556. #----------------------------------------------------------#
  557. # Vesta #
  558. #----------------------------------------------------------#
  559. # Deleting old backup records
  560. for backup_record in $deprecated; do
  561. if [ -e "$USER_DATA/backup.conf" ]; then
  562. sed -i "/DATE='$backup_record/d" $USER_DATA/backup.conf
  563. fi
  564. done
  565. # Concatenating string
  566. backup_str="BACKUP='$user.$DATE.tar'"
  567. backup_str="$backup_str TYPE='$BACKUP_SYSTEM' SIZE='$size'"
  568. backup_str="$backup_str WEB='${web_list// /,}'"
  569. backup_str="$backup_str DNS='${dns_list// /,}'"
  570. backup_str="$backup_str MAIL='${mail_list// /,}'"
  571. backup_str="$backup_str DB='${db_list// /,}'"
  572. backup_str="$backup_str CRON='$cron_list'"
  573. backup_str="$backup_str UDIR='${udir_list// /,}'"
  574. backup_str="$backup_str RUNTIME='$run_time' TIME='$TIME' DATE='$DATE'"
  575. echo "$backup_str" >> $USER_DATA/backup.conf
  576. chmod 660 $USER_DATA/backup.conf
  577. # Clean backup queue
  578. sed -i "/v-backup-user $user /d" $VESTA/data/queue/backup.pipe
  579. # Send notification
  580. if [ "$notify" != 'no' ]; then
  581. subj="$user → backup has been completed"
  582. email=$(get_user_value '$CONTACT')
  583. echo -e "$msg" | $send_mail -s "$subj" $email
  584. fi
  585. # Logging
  586. log_event "$OK" "$EVENT"
  587. exit