Advertisement
Guest User

Untitled

a guest
Jun 9th, 2017
65
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 1.95 KB | None | 0 0
  1. #!/bin/bash
  2.  
  3. cd ~/mailcow-dockerized
  4.  
  5. DBUSER=mailcow
  6. DBPASS=xxxxxxxxxxxxxxxxxxxx
  7. DBNAME=mailcow
  8. DBHOST=mailcow.lxd
  9.  
  10. TBLOLD=mailbox
  11. TBLNEW=mailbox_new
  12. IMPORTTBLNAMES="sogo_user_profile alias alias_domain domain domain_admins $TBLNEW quota2 sender_acl"
  13.  
  14. SSHPASS=xxxxxxxxxxxxxxxx
  15.  
  16. SQLFILE=~/mailcow_legacy_import.sql
  17. OLDMAILPATH=root@mailcow.lxd:/var/vmail
  18. NEWMAILPATH=/var/lib/docker/volumes/mailcowdockerized_vmail-vol-1/_data
  19.  
  20. function syncmail {
  21. sshpass -p $SSHPASS rsync -azP --delete $OLDMAILPATH/$1/ $NEWMAILPATH/$1/
  22. sshpass -p $SSHPASS rsync -azP --delete $OLDMAILPATH/sieve/ $NEWMAILPATH/sieve/
  23. }
  24.  
  25. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e "drop table if exists $TBLNEW"
  26. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e "create table $TBLNEW like $TBLOLD"
  27. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e "insert $TBLNEW select * from $TBLOLD;"
  28.  
  29. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e "ALTER TABLE $TBLNEW MODIFY COLUMN tls_enforce_in TINYINT(1) NOT NULL DEFAULT '0' AFTER domain, MODIFY COLUMN tls_enforce_out TINYINT(1) NOT NULL DEFAULT '0' AFTER tls_enforce_in;"
  30. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e 'ALTER TABLE '$TBLNEW' ADD COLUMN `kind` VARCHAR(255) NOT NULL AFTER `tls_enforce_out`, ADD COLUMN `multiple_bookings` TINYINT(1) NOT NULL DEFAULT '0' AFTER `kind`, ADD COLUMN `wants_tagged_subject` TINYINT(1) NOT NULL DEFAULT '0' AFTER `multiple_bookings`;'
  31.  
  32. mysqldump --replace --no-create-info --default-character-set=utf8mb4 \
  33. --host ${DBHOST} -u${DBUSER} -p${DBPASS} ${DBNAME} \
  34. $IMPORTTBLNAMES > $SQLFILE
  35.  
  36. mysql -h $DBHOST -u $DBUSER -p$DBPASS $DBNAME -e "drop table $TBLNEW"
  37.  
  38. sed -i -e 's/'$TBLNEW'/'$TBLOLD'/g' $SQLFILE
  39.  
  40. source mailcow.conf
  41.  
  42. docker exec -i $(docker-compose ps -q mysql-mailcow) mysql -u${DBUSER} -p${DBPASS} ${DBNAME} < $SQLFILE
  43. rm $SQLFILE
  44.  
  45. #rm $NEWMAILPATH/* -rf
  46.  
  47. docker-compose exec dovecot-mailcow doveadm quota recalc -A
  48.  
  49. syncmail /
  50.  
  51. docker-compose exec dovecot-mailcow doveadm quota recalc -A
  52.  
  53. docker-compose restart
  54.  
  55. cd ~
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement