v-backup-user 20 KB

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