From d43babdedb98b931f3c768db96b1358d26614090 Mon Sep 17 00:00:00 2001 From: Thierry Parmentelat Date: Sat, 16 Feb 2013 11:18:22 +0100 Subject: [PATCH] forget about ifmodule, use rpm to figure if mod_python/mod_wsgi are installed --- plc.d/httpd | 52 +++++++++++++++++++++++++++++++++------------------- 1 file changed, 33 insertions(+), 19 deletions(-) diff --git a/plc.d/httpd b/plc.d/httpd index f218403..e6b409d 100755 --- a/plc.d/httpd +++ b/plc.d/httpd @@ -141,14 +141,41 @@ EOF -e "s/^Listen .*/Listen ${!https_port}/" \ -e "s///" \ $ssl_conf - # this is used to locate the right certificates - server_lower=$(echo $server | tr 'A-Z' 'a-z') - cat <& /dev/null ; then + configure_for_mod_python=true + elif rpm -q mod_wsgi >& /dev/null ; then + configure_for_mod_wsgi=true + else + echo "Requires mod_python or mod_wsgi.... exiting" + exit 1 + fi + + # It would be tempting to use here + # but early tests showed this could be tricky/fragile + # So let's hard-wire it for one module + # A lot of trial-and -error was involved in getting this that way... + + if [ -n "$configure_for_mod_python" ] ; then +#################### for mod_python + cat < + SetHandler mod_python + PythonPath "sys.path + ['/usr/share/plc_api']" + PythonHandler apache.ModPython + +EOF + elif [ -n "$configure_for_mod_wsgi" ] ; then +#################### for mod_wsgi + cat < WSGISocketPrefix run/wsgi - @@ -158,17 +185,6 @@ WSGISocketPrefix run/wsgi SSLCertificateKeyFile /etc/planetlab/${server_lower}_ssl.key SSLCertificateChainFile /etc/planetlab/${server_lower}_ca_ssl.crt -# we prefer mod_python if available, as first attempts at using mod_wsgi -# turned out less reliable - - - SetHandler mod_python - PythonPath "sys.path + ['/usr/share/plc_api']" - PythonHandler apache.ModPython - - - - WSGIScriptAlias /$plc_api_path_noslash /usr/share/plc_api/apache/plc.wsgi # xxx would be cool to be able to tweak this through config WSGIDaemonProcess plcapi-wsgi-ssl user=apache group=apache processes=1 threads=25 @@ -178,12 +194,10 @@ WSGISocketPrefix run/wsgi Options +ExecCGI $(apache_allow) - - EOF - + fi fi done >$plc_conf -- 2.43.0