3 # Copyright 2015 Theke Solutions
4 # Copyright 2016 Koha-Suomi
6 # This file is part of Koha.
8 # This program is free software: you can redistribute it and/or modify
9 # it under the terms of the GNU General Public License as published by
10 # the Free Software Foundation, either version 3 of the License, or
11 # (at your option) any later version.
13 # This program is distributed in the hope that it will be useful,
14 # but WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
16 # GNU General Public License for more details.
18 # You should have received a copy of the GNU General Public License
19 # along with this program. If not, see <http://www.gnu.org/licenses/>.
23 .
/lib
/lsb
/init-functions
25 # Read configuration variable file if it is present
26 [ -r /etc
/default
/koha-common
] && .
/etc
/default
/koha-common
28 # include helper functions
29 if [ -f "/usr/share/koha/bin/koha-functions.sh" ]; then
30 .
"/usr/share/koha/bin/koha-functions.sh"
32 echo "Error: /usr/share/koha/bin/koha-functions.sh not present." 1>&2
38 local scriptname
=$
(basename $0)
43 This script lets you manage the plack daemons for your Koha instances.
46 $scriptname --start|--stop|--restart [--quiet|-q] instancename1 [instancename2...]
47 $scriptname --enable|--disable instancename1 [instancename2]
50 --start Start the plack daemon for the specified instances
51 --stop Stop the plack daemon for the specified instances
52 --restart Restart the plack daemon for the specified instances
53 --enable Enable plack for the specified instances
54 --disable Disable plack for the specified instances
55 --debugger Enable running Plack in debug mode
56 --debugger-key Specify the key the IDE is expecting
57 --debugger-location Specify the host:port for your debugger tool (defaults
59 --debugger-path Specify the path for the debugger library
60 --quiet|-q Make the script quiet about non existent instance names
61 (useful for calling from another scripts).
62 --help|-h Display this help message
71 local PIDFILE
="/var/run/koha/${instancename}/plack.pid"
72 local PLACKSOCKET
="/var/run/koha/${instancename}/plack.sock"
73 local PSGIFILE
="/etc/koha/plack.psgi"
74 local NAME
="${instancename}-koha-plack"
76 if [ -e "/etc/koha/sites/${instancename}/plack.psgi" ]; then
77 # pick instance-specific psgi file
78 PSGIFILE
="/etc/koha/sites/${instancename}/plack.psgi"
79 fi # else stick with the default one
81 _check_and_fix_perms
$instancename
83 PLACK_MAX_REQUESTS
=$
(run_safe_xmlstarlet
$instancename plack_max_requests
)
84 [ -z $PLACK_MAX_REQUESTS ] && PLACK_MAX_REQUESTS
="50"
85 PLACK_WORKERS
=$
(run_safe_xmlstarlet
$instancename plack_workers
)
86 [ -z $PLACK_WORKERS ] && PLACK_WORKERS
="2"
88 instance_user
="${instancename}-koha"
90 environment
="deployment"
91 daemonize
="--daemonize"
92 logging
="--access-log /var/log/koha/${instancename}/plack.log \
93 --error-log /var/log/koha/${instancename}/plack-error.log"
94 max_requests_and_workers
="--max-requests ${PLACK_MAX_REQUESTS} --workers ${PLACK_WORKERS}"
96 if [ "$DEV_INSTALL" = "1" ]; then
97 # Maybe we should switch off debug_mode if DEV_INSTALL is not set?
98 environment
="development"
101 if [ "$debug_mode" = "yes" ]; then
102 environment
="development"
104 logging
="" # remote debugger takes care
105 max_requests_and_workers
="--workers 1"
106 STARMAN
="/usr/bin/perl -d ${STARMAN}"
109 STARMANOPTS
="-M FindBin ${max_requests_and_workers} \
110 --user=${instance_user} --group ${instancename}-koha \
111 --pid ${PIDFILE} ${daemonize} ${logging} \
112 -E ${environment} --socket ${PLACKSOCKET} ${PSGIFILE}"
114 if ! is_plack_running
${instancename}; then
115 export KOHA_CONF
="/etc/koha/sites/${instancename}/koha-conf.xml"
117 log_daemon_msg
"Starting Plack daemon for ${instancename}"
119 # Change to the instance's user dir
121 eval cd ~
$instance_user
123 if ${STARMAN} ${STARMANOPTS}; then
128 # Go back to the original dir
132 log_daemon_msg
"Error: Plack already running for ${instancename}"
139 local instancename
=$1
141 local PIDFILE
="/var/run/koha/${instancename}/plack.pid"
143 if is_plack_running
${instancename}; then
145 log_daemon_msg
"Stopping Plack daemon for ${instancename}"
147 if start-stop-daemon
--pidfile ${PIDFILE} --user="${instancename}-koha" --stop --retry=TERM
/30/KILL
/5; then
153 log_daemon_msg
"Error: Plack not running for ${instancename}"
160 local instancename
=$1
162 local PIDFILE
="/var/run/koha/${instancename}/plack.pid"
164 if is_plack_running
${instancename}; then
165 stop_plack
$instancename && start_plack
$instancename
167 log_daemon_msg
"Error: Plack not running for ${instancename}"
174 local instancename
=$1
175 local instancefile
=$
(get_apache_config_for
"$instancename")
181 if ! is_plack_enabled_opac
$instancefile; then
182 # Uncomment the plack related lines for OPAC
183 sed -i 's:^\s*#\(\s*Include /etc/koha/apache-shared-opac-plack.conf\)$:\1:' "$instancefile"
184 if ! is_plack_enabled_opac
$instancefile; then
185 [ "${quiet}" != "yes" ] && warn
"Plack not enabled for ${instancename} OPAC"
188 [ "${quiet}" != "yes" ] && warn
"Plack enabled for ${instancename} OPAC"
191 [ "${quiet}" != "yes" ] && warn
"Plack already enabled for ${instancename} OPAC"
194 if ! is_plack_enabled_intranet
$instancefile; then
195 # Uncomment the plack related lines for intranet
196 sed -i 's:^\s*#\(\s*Include /etc/koha/apache-shared-intranet-plack.conf\)$:\1:' "$instancefile"
197 if ! is_plack_enabled_intranet
$instancefile; then
198 [ "${quiet}" != "yes" ] && warn
"Plack not enabled for ${instancename} Intranet"
201 [ "${quiet}" != "yes" ] && warn
"Plack enabled for ${instancename} Intranet"
204 [ "${quiet}" != "yes" ] && warn
"Plack already enabled for ${instancename} Intranet"
208 # Fail if it was already plack enabled.
209 if [ $alreadyopac -eq 1 ] && [ $alreadyintra -eq 1 ] ; then
211 elif [ "$alreadyopac" != "$alreadyintra" ]; then
212 [ "${quiet}" != "yes" ] && warn
"$instancename had a plack configuration error. Please confirm it is corrected."
215 # Succeed if both or any plack were turned on.
216 if [ $failopac -eq 0 ] ||
[ $failintra -eq 0 ] ; then
225 local instancename
=$1
226 local instancefile
=$
(get_apache_config_for
"$instancename")
232 if is_plack_enabled_opac
$instancefile ; then
233 # Comment the plack related lines for OPAC
234 sed -i 's:^\(\s*Include /etc/koha/apache-shared-opac-plack.conf\)$:#\1:' "$instancefile"
235 if is_plack_enabled_opac
$instancefile ; then
236 [ "${quiet}" != "yes" ] && warn
"Plack not disabled for ${instancename} OPAC"
239 [ "${quiet}" != "yes" ] && warn
"Plack disabled for ${instancename} OPAC"
242 [ "${quiet}" != "yes" ] && warn
"Plack already disabled for ${instancename} OPAC"
245 if is_plack_enabled_intranet
$instancefile; then
246 # Comment the plack related lines for intranet
247 sed -i 's:^\(\s*Include /etc/koha/apache-shared-intranet-plack.conf\)$:#\1:' "$instancefile"
248 if is_plack_enabled_intranet
$instancefile; then
249 [ "${quiet}" != "yes" ] && warn
"Plack not disabled for ${instancename} Intranet"
252 [ "${quiet}" != "yes" ] && warn
"Plack disabled for ${instancename} Intranet"
255 [ "${quiet}" != "yes" ] && warn
"Plack already disabled for ${instancename} Intranet"
259 # Fail if it was already plack disabled.
260 if [ $alreadyopac -eq 1 ] && [ $alreadyintra -eq 1 ] ; then
262 elif [ "$alreadyopac" != "$alreadyintra" ]; then
263 [ "${quiet}" != "yes" ] && warn
"$instancename had a plack configuration error. Please confirm it is corrected."
266 # Succeed if both or any plack were turned off.
267 if [ $failopac -eq 0 ] ||
[ $failintra -eq 0 ] ; then
276 local apache_version_ok
="no"
277 local required_modules
="headers proxy_http"
278 local missing_modules
=""
280 if /usr
/sbin
/apache2ctl
-v |
grep -q "Server version: Apache/2.4"; then
281 apache_version_ok
="yes"
284 for module
in ${required_modules}; do
285 if ! /usr
/sbin
/apachectl
-M 2> /dev
/null |
grep -q ${module}; then
286 missing_modules
="${missing_modules}${module} "
290 if [ "${apache_version_ok}" != "yes" ]; then
291 warn
"WARNING: koha-plack requires Apache 2.4.x and you don't have that."
294 if [ "${missing_modules}" != "" ]; then
296 WARNING: koha-plack requires some Apache modules that you are missing.
297 You can install them with:
299 sudo a2enmod ${missing_modules}
306 _check_and_fix_perms
()
310 local files
="/var/log/koha/${instance}/plack.log \
311 /var/log/koha/${instance}/plack-error.log"
315 if [ ! -e "${file}" ]; then
318 chown
"${instance}-koha":"${instance}-koha" ${file}
324 if [ "$op" = "" ]; then
327 die "Error
: only one action can be specified.
"
333 local PERL5LIB=$PERL5LIB
334 local KOHA_HOME=$KOHA_HOME
335 local DEV_INSTALL=$DEV_INSTALL
337 adjust_paths_dev_install $name
338 PERL5LIB=$PERL5LIB:$KOHA_HOME/installer:$KOHA_HOME/lib/installer
339 # If debug mode is enabled, add the debugger lib path
340 # to PERL5LIB if appropriate
341 #FIXME: many of these variables should be set in a higher scope
342 if [ "$debug_mode" = "yes" ]; then
343 if [ "$debugger_path" != "" ]; then
344 PERL5LIB="${debugger_path}":$PERL5LIB
346 export PERL5DB="BEGIN
{ require q
(${debugger_path}/perl5db.pl
) }"
347 export PERLDB_OPTS="RemotePort
=${debugger_location} async
=1 LogFile
=/var
/log
/koha
/${name}/plack-debug.log
"
348 export DBGP_IDEKEY=${debugger_key}
375 STARMAN=$(which starman)
380 debugger_location="localhost
:9000"
383 # Read command line parameters
384 while [ $# -gt 0 ]; do
414 debugger_location="$2"
420 die "Error
: invalid option switch
($1)" ;;
422 # We expect the remaining stuff are the instance names
428 [ "${quiet}" != "yes" ] && check_env_and_warn
434 if [ $# -gt 0 ]; then
435 # We have at least one instance name
438 if is_instance $name; then
441 if [ "$quiet" = "no
" ]; then
442 log_daemon_msg "Error
: Invalid instance name
$name"
449 if [ "$quiet" = "no
" ]; then
450 warn "Error
: you must provide
at least one instance name
"