aboutsummaryrefslogtreecommitdiff
path: root/handlers/svn.in
diff options
context:
space:
mode:
Diffstat (limited to 'handlers/svn.in')
-rw-r--r--handlers/svn.in80
1 files changed, 80 insertions, 0 deletions
diff --git a/handlers/svn.in b/handlers/svn.in
new file mode 100644
index 0000000..377d71c
--- /dev/null
+++ b/handlers/svn.in
@@ -0,0 +1,80 @@
+# -*- mode: sh; sh-basic-offset: 3; indent-tabs-mode: nil; -*-
+#
+# this handler will backup subversion repostitories.
+#
+
+getconf src /var/lib/svn
+getconf dest /var/backups/svn
+getconf tmp /var/backups/svn.tmp
+getconf HOTBACKUP "/usr/bin/svnadmin hotcopy"
+getconf vsname
+
+error=0
+
+# Decide if the handler should operate on a vserver or on the host.
+# In the former case, check that $vsname exists and is running.
+local usevserver=no
+local vroot
+if [ $vservers_are_available = yes ]; then
+ if [ -n "$vsname" ]; then
+ # does it exist ?
+ if ! vservers_exist "$vsname" ; then
+ fatal "The vserver given in vsname ($vsname) does not exist."
+ fi
+ # is it running ?
+ $VSERVERINFO -q $vsname RUNNING
+ if [ $? -ne 0 ]; then
+ fatal "The vserver $vsname is not running."
+ fi
+ # everything ok
+ info "Using vserver '$vsname'."
+ usevserver=yes
+ vroot="$VROOTDIR/$vsname"
+ else
+ info "No vserver name specified, actions will be performed on the host."
+ fi
+fi
+
+cd $vroot$src
+for repo in `find . -name svnserve.conf`
+do
+ repo=`dirname $repo`
+ repo=`dirname $repo`
+
+ ret=`mkdir -p $vroot$tmp/$repo 2>&1`
+ code=$?
+ if [ "$ret" ]; then
+ debug "$ret"
+ fi
+ if [ $code != 0 ]; then
+ error "command failed mkdir -p $vroot$tmp/$repo"
+ fi
+
+ if [ $usevserver = yes ]
+ then
+ ret=`$VSERVER $vsname exec $HOTBACKUP $src/$repo $tmp/$repo 2>&1`
+ else
+ ret=`$HOTBACKUP $src/$repo $tmp/$repo 2>&1`
+ fi
+ code=$?
+ if [ "$ret" ]; then
+ debug "$ret"
+ fi
+ if [ $code != 0 ]; then
+ error "command failed -- $HOTBACKUP $vroot$src/$repo $vroot$tmp/$repo"
+ error=1
+ fi
+done
+
+if [ $error -eq 1 ]; then
+ echo "Error: because of earlier errors, we are leaving svn backups in $vroot$tmp instead of $vroot$dest"
+else
+ if [ -d $vroot$dest -a -d $vroot$tmp ]; then
+ rm -rf $vroot$dest
+ fi
+ if [ -d $vroot$tmp ]; then
+ mv $vroot$tmp $vroot$dest
+ fi
+fi
+
+exit 0