Bug 31095: Remove keyed_on_code
[koha.git] / debian / scripts / koha-mysql
1 #!/bin/sh
2 #
3 # koha-mysql: provide an interactive mysql shell set up for the specified
4 #   koha instance.
5 # Copyright 2011  Catalyst IT, Ltd
6
7 # This program is free software: you can redistribute it and/or modify
8 # it under the terms of the GNU General Public License as published by
9 # the Free Software Foundation, either version 3 of the License, or
10 # (at your option) any later version.
11
12 # This program is distributed in the hope that it will be useful,
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15 # GNU General Public License for more details.
16
17 # You should have received a copy of the GNU General Public License
18 # along with this program.  If not, see <http://www.gnu.org/licenses/>.
19
20 set -e
21 umask 0077
22
23 # include helper functions
24 if [ -f "/usr/share/koha/bin/koha-functions.sh" ]; then
25     . "/usr/share/koha/bin/koha-functions.sh"
26 else
27     echo "Error: /usr/share/koha/bin/koha-functions.sh not present." 1>&2
28     exit 1
29 fi
30
31 usage()
32 {
33     local scriptname=$0
34     cat <<EOF
35 Run mysql in the context of a given Koha instance.
36
37 Usage: $scriptname instancename [ optional mysql arguments ]
38
39 EOF
40 }
41
42 # Parse command line.
43 [ $# -ge 1 ] || ( usage ; die "Missing instance name..." )
44
45 name="$1"
46
47 is_instance "$name" || ( usage; die "Unknown instance '$name'" )
48
49 shift # remove instance name from argument list.
50 kohaconfig="/etc/koha/sites/$name/koha-conf.xml"
51
52 mysqlhost="$( xmlstarlet sel -t -v 'yazgfs/config/hostname' $kohaconfig )"
53 mysqldb="$( xmlstarlet sel -t -v 'yazgfs/config/database' $kohaconfig )"
54 mysqluser="$( xmlstarlet sel -t -v 'yazgfs/config/user' $kohaconfig )"
55 mysqlpass="$( xmlstarlet sel -t -v 'yazgfs/config/pass' $kohaconfig )"
56
57 mysqltz="$( xmlstarlet sel -t -v 'yazgfs/config/timezone' $kohaconfig || true )"
58 if [ "$mysqltz" != "" ]
59 then
60     mysql --host="$mysqlhost" --user="$mysqluser" --password="$mysqlpass" --init-command="SET time_zone='$mysqltz'" \
61         "$mysqldb"  "${@}"
62 else
63     mysql --host="$mysqlhost" --user="$mysqluser" --password="$mysqlpass" \
64         "$mysqldb"  "${@}"
65 fi