]> gitweb.fluxo.info Git - hydra.git/commitdiff
Adding backup-restore-email
authorSilvio Rhatto <rhatto@riseup.net>
Wed, 27 Jun 2012 20:54:25 +0000 (17:54 -0300)
committerSilvio Rhatto <rhatto@riseup.net>
Wed, 27 Jun 2012 20:54:25 +0000 (17:54 -0300)
share/hydractl/backup-restore-email [new file with mode: 0755]
share/hydractl/backup-restore-hidden

diff --git a/share/hydractl/backup-restore-email b/share/hydractl/backup-restore-email
new file mode 100755 (executable)
index 0000000..f0d7979
--- /dev/null
@@ -0,0 +1,72 @@
+#!/bin/bash
+#
+# Email backup restoration.
+#
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as
+# published by the Free Software Foundation, either version 3 of the
+# License, or (at your option) any later version.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public
+# License along with this program.  If not, see
+# <http://www.gnu.org/licenses/>.
+
+# Load.
+source $APP_BASE/lib/hydra/functions || exit 1
+hydra_config_load
+
+# Parameters.
+DATE="`date +%Y%m%d`"
+EMAIL_DIR="/var/mail/virtual"
+
+# Check restore strategy.
+if [ "$1" == "localhost" ] || [ "$1" == "`facter hostname`" ]; then
+  hydra_backup_environment_local
+else
+  hydra_backup_environment_remote $1 restore
+fi
+
+# Check if folder exist on the backup.
+if [ ! -d "$RESTOREDIR/$EMAIL_DIR" ]; then
+  echo "Email folder does not exist: $RESTOREDIR/$EMAIL_DIR"
+  exit 1
+fi
+
+# Set git user.
+if hydra_check_user vmail; then
+  EMAIL_USER="vmail"
+else
+  EMAIL_USER="root"
+fi
+
+# Set git group.
+if hydra_check_group vmail; then
+  EMAIL_GROUP="vmail"
+else
+  EMAIL_GROUP="root"
+fi
+
+# TODO: Backup it?
+#hydractl backup-email
+
+# Restore email folder from backup.
+#
+# Symlink creation on site instances like drupal should be done
+# already by backup-restore-site.
+for folder in `ls $RESTOREDIR/$EMAIL_DIR`; do
+  if [ -d "$EMAIL_DIR/$folder" ]; then
+    echo "Email for user $email already exists on $EMAIL_DIR/$folder!"
+  else
+    echo "Processing $EMAIL_DIR/$folder..."
+    cp -a $RESTOREDIR/$EMAIL_DIR/$folder $EMAIL_DIR/$folder
+  fi
+done
+
+# Fix permissions.
+chown -R $EMAIL_USER.$EMAIL_GROUP $EMAIL_DIR
+
index 24cd9bf3bfd203ce72b254355779a9ef67f2ac62..4e2ba2a41b5b409a9357c254b81fe671b471f36c 100755 (executable)
@@ -63,12 +63,13 @@ for folder in `ls $RESTOREDIR/$HIDDEN_DIR`; do
     # A hidden service already exists
     if ! diff "$HIDDEN_DIR/$folder/hostname" "$RESTOREDIR/$HIDDEN_DIR/$folder/hostname" &> /dev/null; then
       # They're different hidden services!
-      echo "Hidden service $hidden already exist on $HIDDEN_DIR/$folder and differs from backup!"
+      echo "Hidden service $hidden already exists on $HIDDEN_DIR/$folder and differs from backup!"
       echo "Please fix this conflict manually and restore backups again."
     else
       echo "Hidden service $hidden already in place, no need to copy."
     fi
   else
+    echo "Processing $HIDDEN_DIR/$folder..."
     rm -rf $HIDDEN_DIR/$folder
     cp -a $RESTOREDIR/$HIDDEN_DIR/$folder $HIDDEN_DIR/$folder
   fi