3 # koha-dump: dump all contents and configs for a Koha site
4 # Copyright 2010 Catalyst IT, Ltd
6 # This program is free software: you can redistribute it and/or modify
7 # it under the terms of the GNU General Public License as published by
8 # the Free Software Foundation, either version 3 of the License, or
9 # (at your option) any later version.
11 # This program is distributed in the hope that it will be useful,
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 # GNU General Public License for more details.
16 # You should have received a copy of the GNU General Public License
17 # along with this program. If not, see <http://www.gnu.org/licenses/>.
23 # Make sure the files we create are not accessible by anyone else.
34 [ "$#" = 1 ] || die "Usage: $0 instancename"
36 kohaconfig="/etc/koha/sites/$name/koha-conf.xml"
37 date="$(date +%Y-%m-%d)"
39 echo "Dumping Koha site $name:"
43 mysqlhost="$(sed -n '/.*<hostname>\(.*\)<\/hostname>.*/s::\1:p' $kohaconfig)"
44 mysqldb="$(sed -n '/.*<database>\(.*\)<\/database>.*/s::\1:p' $kohaconfig)"
45 mysqluser="$(sed -n '/.*<user>\(.*\)<\/user>.*/s::\1:p' $kohaconfig | tail -n1)"
46 mysqlpass="$(sed -n '/.*<pass>\(.*\)<\/pass>.*/s::\1:p' $kohaconfig)"
47 dbdump="/var/spool/koha/$name/$name-$date.sql.gz"
48 echo "* DB to $dbdump"
49 mysqldump --databases --host="$mysqlhost" \
50 --user="$mysqluser" --password="$mysqlpass" "$mysqldb" |
52 chown "root:$name-koha" "$dbdump"
56 # Dump configs, logs, etc.
57 metadump="/var/spool/koha/$name/$name-$date.tar.gz"
58 echo "* configs, logs to $metadump"
59 tar -C / -czf "$metadump" \
60 "etc/koha/sites/$name" \
61 "etc/apache2/sites-available/$name" \
62 "etc/apache2/sites-enabled/$name" \
63 "var/lib/koha/$name" \