Add koha-dump, a script to dump a Koha site.
authorLars Wirzenius <lars@catalyst.net.nz>
Tue, 25 May 2010 01:44:12 +0000 (13:44 +1200)
committerChris Cormack <chrisc@catalyst.net.nz>
Wed, 26 May 2010 04:30:22 +0000 (16:30 +1200)
Signed-off-by: Galen Charlton <gmcharlt@gmail.com>
debian/scripts/koha-dump [new file with mode: 0755]

diff --git a/debian/scripts/koha-dump b/debian/scripts/koha-dump
new file mode 100755 (executable)
index 0000000..ef3e4cc
--- /dev/null
@@ -0,0 +1,65 @@
+#!/bin/sh
+#
+# koha-dump: dump all contents and configs for a Koha site
+# Copyright 2010  Catalyst IT, Ltd
+# 
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU 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 General Public License for more details.
+# 
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+
+set -e
+
+
+# Make sure the files we create are not accessible by anyone else.
+umask 0077
+
+
+die() {
+    echo "$@" 1>&2
+    exit 1
+}
+
+
+# Parse command line.
+[ "$#" = 1 ] || die "Usage: $0 instancename"
+name="$1"
+kohaconfig="/etc/koha/sites/$name/koha-conf.xml"
+date="$(date +%Y-%m-%d)"
+
+echo "Dumping Koha site $name:"
+
+
+# Dump database.
+mysqlhost="$(sed -n '/.*<hostname>\(.*\)<\/hostname>.*/s::\1:p' $kohaconfig)"
+mysqldb="$(sed -n '/.*<database>\(.*\)<\/database>.*/s::\1:p' $kohaconfig)"
+mysqluser="$(sed -n '/.*<user>\(.*\)<\/user>.*/s::\1:p' $kohaconfig | tail -n1)"
+mysqlpass="$(sed -n '/.*<pass>\(.*\)<\/pass>.*/s::\1:p' $kohaconfig)"
+dbdump="/var/spool/koha/$name/$name-$date.sql.gz"
+echo "* DB to $dbdump"
+mysqldump --databases --host="$mysqlhost" \
+    --user="$mysqluser" --password="$mysqlpass" "$mysqldb" | 
+    gzip > "$dbdump"
+chown "root:$name-koha" "$dbdump"
+chmod g+r "$dbdump"
+
+
+# Dump configs, logs, etc.
+metadump="/var/spool/koha/$name/$name-$date.tar.gz"
+echo "* configs, logs to $metadump"
+tar -C / -czf "$metadump" \
+    "etc/koha/sites/$name" \
+    "etc/apache2/sites-available/$name" \
+    "etc/apache2/sites-enabled/$name" \
+    "var/log/koha/$name"
+
+echo "Done."