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/>.
22 # include helper functions
23 if [ -f "/usr/share/koha/bin/koha-functions.sh" ]; then
24 .
"/usr/share/koha/bin/koha-functions.sh"
26 echo "Error: /usr/share/koha/bin/koha-functions.sh not present." 1>&2
30 # Make sure the files we create are not accessible by anyone else.
35 local scriptname
=$
(basename $0)
40 This script dumps your Koha instance data for backup or migration.
43 $scriptname [--quiet|-q] [--exclude-indexes] instancename1 [instancename2...]
46 --exclude-indexes Include Zebra indexes on the backup.
47 --quiet|-q Make the script avoid printing to STDOUT
48 (useful for calling from another scripts).
49 --help|-h Display this help message
50 --without-db-name Do not include database name
59 kohaconfig
="/etc/koha/sites/$name/koha-conf.xml"
60 date="$(date +%Y-%m-%d)"
62 [ "$quiet" = "no" ] && echo "Dumping Koha site $name:"
65 mysqlhost
="$( xmlstarlet sel -t -v 'yazgfs/config/hostname' $kohaconfig )"
66 mysqldb
="$( xmlstarlet sel -t -v 'yazgfs/config/database' $kohaconfig )"
67 mysqluser
="$( xmlstarlet sel -t -v 'yazgfs/config/user' $kohaconfig )"
68 mysqlpass
="$( xmlstarlet sel -t -v 'yazgfs/config/pass' $kohaconfig )"
69 backupdir
="$( xmlstarlet sel -t -v 'yazgfs/config/backupdir' $kohaconfig || true )"
70 [ -z "$backupdir" ] && backupdir
="/var/spool/koha/$name"
71 dbdump
="$backupdir/$name-$date.sql.gz"
72 [ "$quiet" = "no" ] && echo "* DB to $dbdump"
74 [ "$without_db_name" = "yes" ] && dbflag
=""
75 mysqldump
$dbflag --host="$mysqlhost" \
76 --user="$mysqluser" --password="$mysqlpass" "$mysqldb" |
78 chown
"root:$name-koha" "$dbdump"
81 instancefile
="$name.conf"
83 # Dump configs, logs, etc.
84 metadump
="$backupdir/$name-$date.tar.gz"
85 [ "$quiet" = "no" ] && echo "* configs, logs to $metadump"
87 if [ "$exclude_indexes" = "yes" ]; then
88 excludes
="--exclude=var/lib/koha/$name/biblios \
89 --exclude=var/lib/koha/$name/authorities"
92 tar -czf "$metadump" -C / $excludes \
93 "etc/koha/sites/$name" \
94 "etc/apache2/sites-available/$instancefile" \
95 "etc/apache2/sites-enabled/$instancefile" \
96 "var/lib/koha/$name" \
99 [ "$quiet" = "no" ] && echo "Done."
107 while [ $# -gt 0 ]; do
111 exclude_indexes
="yes"
114 without_db_name
="yes"
122 die
"Error: invalid option switch ($1)" ;;
124 # We expect the remaining stuff are the instance names
130 # Read instance names
131 if [ $# -gt 0 ]; then
132 # We have at least one instance name
135 if is_instance
$name; then
140 if [ "$quiet" = "no" ]; then
141 die
"Error: Invalid instance name $name"
149 if [ "$quiet" = "no" ]; then
150 die
"Error: you must provide at least one instance name"