Tomas Cohen Arazi
d863757fa7
This patch adds the --plack and --noplack option switches to koha-list for filtering instances to be listed. This is particularly important for init scripts and cronjobs. To test: - Play with koha-list --plack and koha-plack --enable/--disable and verify that koha-list returns the expected results. Signed-off-by: Josef Moravec <josef.moravec@gmail.com> Signed-off-by: Jonathan Druart <jonathan.druart@bugs.koha-community.org> Signed-off-by: Tomas Cohen Arazi <tomascohen@unc.edu.ar>
227 lines
5.5 KiB
Bash
Executable file
227 lines
5.5 KiB
Bash
Executable file
#!/bin/sh
|
|
#
|
|
# koha-list -- List all Koha instances.
|
|
# 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
|
|
|
|
# include helper functions
|
|
if [ -f "/usr/share/koha/bin/koha-functions.sh" ]; then
|
|
. "/usr/share/koha/bin/koha-functions.sh"
|
|
else
|
|
echo "Error: /usr/share/koha/bin/koha-functions.sh not present." 1>&2
|
|
exit 1
|
|
fi
|
|
|
|
show_instances()
|
|
{
|
|
local show=$1
|
|
local show_email=$2
|
|
local show_sip=$3
|
|
|
|
for instance in $( get_instances ); do
|
|
case $show in
|
|
"all")
|
|
if instance_filter_email $instance $show_email && \
|
|
instance_filter_plack $instance $show_plack && \
|
|
instance_filter_sip $instance $show_sip; then
|
|
echo $instance
|
|
fi ;;
|
|
"enabled")
|
|
if is_enabled $instance; then
|
|
if instance_filter_email $instance $show_email && \
|
|
instance_filter_plack $instance $show_plack && \
|
|
instance_filter_sip $instance $show_sip; then
|
|
echo $instance
|
|
fi
|
|
fi ;;
|
|
"disabled")
|
|
if ! is_enabled $instance; then
|
|
if instance_filter_email $instance $show_email && \
|
|
instance_filter_plack $instance $show_plack && \
|
|
instance_filter_sip $instance $show_sip; then
|
|
echo $instance
|
|
fi
|
|
fi ;;
|
|
esac
|
|
done
|
|
}
|
|
|
|
|
|
instance_filter_sip()
|
|
{
|
|
local instancename=$1
|
|
local show_sip=$2;
|
|
|
|
case $show_sip in
|
|
"all")
|
|
return 0 ;;
|
|
"enabled")
|
|
if is_sip_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
"disabled")
|
|
if ! is_sip_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
esac
|
|
|
|
# Didn't match any criteria
|
|
return 1
|
|
}
|
|
|
|
instance_filter_plack()
|
|
{
|
|
local instancename=$1
|
|
local show_plack=$2;
|
|
|
|
case $show_plack in
|
|
"all")
|
|
return 0 ;;
|
|
"enabled")
|
|
if is_plack_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
"disabled")
|
|
if ! is_plack_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
esac
|
|
|
|
# Didn't match any criteria
|
|
return 1
|
|
}
|
|
|
|
instance_filter_email()
|
|
{
|
|
local instancename=$1
|
|
local show_email=$2;
|
|
|
|
case $show_email in
|
|
"all")
|
|
return 0 ;;
|
|
"enabled")
|
|
if is_email_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
"disabled")
|
|
if ! is_email_enabled $instancename; then
|
|
return 0
|
|
fi ;;
|
|
esac
|
|
|
|
# Didn't match any criteria
|
|
return 1
|
|
}
|
|
|
|
set_show()
|
|
{
|
|
local show_param=$1
|
|
|
|
if [ "$show" = "all" ]; then
|
|
show=$show_param
|
|
else
|
|
die "Error: --enabled and --disabled are mutually exclusive."
|
|
fi
|
|
}
|
|
|
|
set_show_email()
|
|
{
|
|
local email_param=$1
|
|
|
|
if [ "$show_email" = "all" ]; then
|
|
show_email=$email_param
|
|
else
|
|
die "Error: --email and --noemail are mutually exclusive."
|
|
fi
|
|
}
|
|
|
|
set_show_plack()
|
|
{
|
|
local plack_param=$1
|
|
|
|
if [ "$show_plack" = "all" ]; then
|
|
show_plack=$plack_param
|
|
else
|
|
die "Error: --plack and --noplack are mutually exclusive."
|
|
fi
|
|
}
|
|
|
|
set_show_sip()
|
|
{
|
|
local sip_param=$1
|
|
|
|
if [ "$show_sip" = "all" ]; then
|
|
show_sip=$sip_param
|
|
else
|
|
die "Error: --sip and --nosip are mutually exclusive."
|
|
fi
|
|
}
|
|
|
|
usage()
|
|
{
|
|
local scriptname=$0
|
|
|
|
cat <<EOH
|
|
Lists Koha instances, optionally only those that are enabled or have
|
|
email turned on.
|
|
|
|
Usage: $scriptname [--enabled|--disabled] [--email|--noemail] [--sip|--nosip] [-h]
|
|
Options:
|
|
--enabled Show enabled instances
|
|
--disabled Show disabled instances
|
|
--email Show instances with email enabled
|
|
--noemail Show instances with email disabled
|
|
--sip Show instances with SIP enabled
|
|
--nosip Show instances with SIP disabled
|
|
--plack Show instances with Plack enabled
|
|
--noplack Show instances with Plack disabled
|
|
--help | -h Show this help
|
|
|
|
The filtering options can be combined, and you probably want to do this
|
|
(except --email and --noemail, or --enabled and --disabled, that's just silly.)
|
|
EOH
|
|
}
|
|
|
|
show="all"
|
|
show_email="all"
|
|
show_sip="all"
|
|
show_plack="all"
|
|
|
|
args=$(getopt -l help,enabled,disabled,email,noemail,sip,nosip,plack,noplack -o h -n $0 -- "$@")
|
|
set -- $args
|
|
|
|
while [ ! -z "$1" ]
|
|
do
|
|
case "$1" in
|
|
-h|--help) usage; exit;;
|
|
--email) set_show_email "enabled" ;;
|
|
--noemail) set_show_email "disabled" ;;
|
|
--sip) set_show_sip "enabled" ;;
|
|
--nosip) set_show_sip "disabled" ;;
|
|
--plack) set_show_plack "enabled" ;;
|
|
--noplack) set_show_plack "disabled" ;;
|
|
--enabled) set_show "enabled" ;;
|
|
--disabled) set_show "disabled" ;;
|
|
*) break;;
|
|
esac
|
|
shift
|
|
done
|
|
|
|
show_instances $show $show_email $show_sip
|
|
|
|
exit 0
|