diff options
| author | Silvio Rhatto <rhatto@riseup.net> | 2012-01-04 15:43:08 -0200 | 
|---|---|---|
| committer | Silvio Rhatto <rhatto@riseup.net> | 2012-01-04 15:43:08 -0200 | 
| commit | 26cbb26cebd495fd6260b6af65b37fe5c8a8c00b (patch) | |
| tree | 02f5dae382c02f04e87d37816e409252f26579a7 /share | |
| parent | f360acf0fab1d941bc7de8bec3d22aabd64f49fe (diff) | |
| download | hydra-26cbb26cebd495fd6260b6af65b37fe5c8a8c00b.tar.gz hydra-26cbb26cebd495fd6260b6af65b37fe5c8a8c00b.tar.bz2 | |
Support for restoring backups from /var/backups/restore; svn and git restore support
Diffstat (limited to 'share')
| -rwxr-xr-x | share/hydra/deploy | 2 | ||||
| -rwxr-xr-x | share/hydractl/backup-restore | 10 | ||||
| -rwxr-xr-x | share/hydractl/backup-restore-gitosis | 45 | ||||
| -rwxr-xr-x | share/hydractl/backup-restore-site | 6 | ||||
| -rwxr-xr-x | share/hydractl/backup-restore-svn | 46 | 
5 files changed, 91 insertions, 18 deletions
| diff --git a/share/hydra/deploy b/share/hydra/deploy index adeb6c8..0a8a5de 100755 --- a/share/hydra/deploy +++ b/share/hydra/deploy @@ -9,7 +9,7 @@ hydra_config_load  # Command line arguments  NODES="$*" -COMMIT="d8e20cc9fa92f07def15ebf3041405627fb66eae" +COMMIT="f360acf0fab1d941bc7de8bec3d22aabd64f49fe"  # Build node list  if [ -z "$NODES" ]; then diff --git a/share/hydractl/backup-restore b/share/hydractl/backup-restore index 160ed5e..a5bfd42 100755 --- a/share/hydractl/backup-restore +++ b/share/hydractl/backup-restore @@ -2,12 +2,16 @@  #  # Backup restoration.  # -# TODO: optionally restore from local backup -#  # Load.  source $APP_BASE/lib/hydra/functions || exit 1  hydra_config_load -hydra_backup_environment_remote $* +# Check restore strategy. +if [ "$1" == "localhost" ]; then +  hydra_backup_environment_local $2 restore +else +  hydra_backup_environment_remote $1 restore +fi +  duplicity restore file:///$BACKUPDIR/ $RESTOREDIR/ diff --git a/share/hydractl/backup-restore-gitosis b/share/hydractl/backup-restore-gitosis index 7da4a05..f569a8e 100755 --- a/share/hydractl/backup-restore-gitosis +++ b/share/hydractl/backup-restore-gitosis @@ -2,15 +2,48 @@  #  # Gitosis backup restoration.  # -# TODO  # Load.  source $APP_BASE/lib/hydra/functions || exit 1  hydra_config_load -hydra_backup_environment_remote $* +# Parameters. +DATE="`date +%Y%m%d`" -# Check if folder exist on the backup -# Check if there's already a site folder and backup it -# Copy site folder from backup -# Fix permissions +# Check restore strategy. +if [ "$1" == "localhost" ] || [ "$1" == "`facter hostname`" ]; then +  hydra_backup_environment_local $2 restore +else +  hydra_backup_environment_remote $1 restore +fi + +# Check if folder exist on the backup. +if [ ! -d "$RESTOREDIR/var/git" ]; then +  echo "Git folder does not exist: $RESTOREDIR/var/git" +  exit 1 +fi + +# Set git user. +if hydra_check_user gitosis; then +  $GIT_USER="gitosis" +else +  $GIT_USER="root" +fi + +# Set git group. +if hydra_check_group gitosis; then +  $GIT_GROUP="gitosis" +else +  $GIT_GROUP="root" +fi + +# TODO: more like backup-site +# Backup it. +mkdir -p /var/site/backups/git/ +mv /var/git /var/site/backups/git/$DATE + +# Copy site folder from backup. +cp -a $RESTOREDIR/var/git /var/git + +# Fix permissions. +chown -R $GIT_USER.$GIT_GROUP /var/git diff --git a/share/hydractl/backup-restore-site b/share/hydractl/backup-restore-site index 4604755..ae8f87a 100755 --- a/share/hydractl/backup-restore-site +++ b/share/hydractl/backup-restore-site @@ -19,8 +19,10 @@ if [ -z "$SITE" ]; then    exit 1  fi -# Check restore stratety. -if [ "$1" == "localhost" ]; then +# Check restore strategy. +if [ "$1" == "backups" ]; then +  hydra_backup_environment_local_website $2 restore +elif [ "$1" == "localhost" ] || [ "$1" == "`facter hostname`" ]; then    hydra_backup_environment_local $2 restore  else    hydra_backup_environment_remote $1 restore diff --git a/share/hydractl/backup-restore-svn b/share/hydractl/backup-restore-svn index e4b1660..2f15563 100755 --- a/share/hydractl/backup-restore-svn +++ b/share/hydractl/backup-restore-svn @@ -2,15 +2,49 @@  #  # Subversion backup restoration.  # -# TODO  # Load.  source $APP_BASE/lib/hydra/functions || exit 1  hydra_config_load -hydra_backup_environment_remote $* +# Parameters. +DATE="`date +%Y%m%d`" -# Check if folder exist on the backup -# Check if there's already a site folder and backup it -# Copy site folder from backup -# Fix permissions +# Check restore strategy. +if [ "$1" == "localhost" ] || [ "$1" == "`facter hostname`" ]; then +  hydra_backup_environment_local $2 restore +else +  hydra_backup_environment_remote $1 restore +fi + +# Check if folder exist on the backup. +if [ -d "$RESTOREDIR/var/svn" ]; then +  echo "SVN folder does not exist: $RESTOREDIR/var/svn" +  exit 1 +fi + +# TODO: more like backup-site +# Backup it. +mkdir -p /var/site/backups/svn/ +mv /var/svn /var/site/backups/svn/$DATE + +# Set svn user. +if hydra_check_user svn; then +  $SVN_USER="svn" +else +  $SVN_USER="root" +fi + +# Set svn group. +if hydra_check_group svn; then +  $SVN_GROUP="svn" +else +  $SVN_GROUP="root" +fi + +# Copy site folder from backup. +cp -a $RESTOREDIR/var/svn /var/svn + +# Fix permissions. +chown root.root /var/svn +chown -R $SVN_USER.$SVN_GROUP /var/svn/* | 
