Bug 14056: Small punctuation error in description for deleting a holiday
[koha.git] / debian / scripts / koha-dump
1 #!/bin/sh
2 #
3 # koha-dump: dump all contents and configs for a Koha site
4 # Copyright 2010  Catalyst IT, Ltd
5
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.
10
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.
15
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/>.
18
19
20 set -e
21
22 # include helper functions
23 if [ -f "/usr/share/koha/bin/koha-functions.sh" ]; then
24     . "/usr/share/koha/bin/koha-functions.sh"
25 else
26     echo "Error: /usr/share/koha/bin/koha-functions.sh not present." 1>&2
27     exit 1
28 fi
29
30 # Make sure the files we create are not accessible by anyone else.
31 umask 0077
32
33 # Parse command line.
34 [ "$#" = 1 ] || die "Usage: $0 instancename"
35 name="$1"
36 kohaconfig="/etc/koha/sites/$name/koha-conf.xml"
37 date="$(date +%Y-%m-%d)"
38
39 echo "Dumping Koha site $name:"
40
41
42 # Dump database.
43 mysqlhost="$( xmlstarlet sel -t -v 'yazgfs/config/hostname' $kohaconfig )"
44 mysqldb="$( xmlstarlet sel -t -v 'yazgfs/config/database' $kohaconfig )"
45 mysqluser="$( xmlstarlet sel -t -v 'yazgfs/config/user' $kohaconfig )"
46 mysqlpass="$( xmlstarlet sel -t -v 'yazgfs/config/pass' $kohaconfig )"
47 backupdir="$( xmlstarlet sel -t -v 'yazgfs/config/backupdir' $kohaconfig || true )"
48 [ -z "$backupdir" ] && backupdir="/var/spool/koha/$name"
49 dbdump="$backupdir/$name-$date.sql.gz"
50 echo "* DB to $dbdump"
51 mysqldump --databases --host="$mysqlhost" \
52     --user="$mysqluser" --password="$mysqlpass" "$mysqldb" | 
53     gzip > "$dbdump"
54 chown "root:$name-koha" "$dbdump"
55 chmod g+r "$dbdump"
56
57 instancefile="$name.conf"
58
59 # Dump configs, logs, etc.
60 metadump="$backupdir/$name-$date.tar.gz"
61 echo "* configs, logs to $metadump"
62 tar -C / -czf "$metadump" \
63     "etc/koha/sites/$name" \
64     "etc/apache2/sites-available/$instancefile" \
65     "etc/apache2/sites-enabled/$instancefile" \
66     "var/lib/koha/$name" \
67     "var/log/koha/$name"
68
69 echo "Done."