2
# Copyright (C) 2007-2008 The University of Melbourne
4
# This program is free software; you can redistribute it and/or modify
5
# it under the terms of the GNU General Public License as published by
6
# the Free Software Foundation; either version 2 of the License, or
7
# (at your option) any later version.
9
# This program is distributed in the hope that it will be useful,
10
# but WITHOUT ANY WARRANTY; without even the implied warranty of
11
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12
# GNU General Public License for more details.
14
# You should have received a copy of the GNU General Public License
15
# along with this program; if not, write to the Free Software
16
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
18
# Module: dispatch_handler
22
# This is a mod_python handler program. The correct way to call it is to have
23
# Apache send all requests to be handled by the module 'dispatch'.
25
# This file is a wrapper around the dispatch module, necessary because
26
# mod_python does not (for some reason) load the handler directory into
28
# It requires that the server config has the following line:
29
# PythonOption ivle.handlerpath "PATH-TO-IVLE"
31
# Sets sys.path with the correct path, then calls the handler in the dispatch
35
from mod_python import apache
39
# The Apache httpd.conf needs to specify ivle.handlerpath as an option
43
handlerpath = req.get_options()['ivle.handlerpath']
45
# Note: "Internal Server Error" if "ivle.handlerpath" is not set
46
# (this is valid as it reflects an error in the Apache config
47
# But give useful feedback in debug mode
48
raise Exception("Missing configuration option 'ivle.handlerpath'")
50
if handlerpath not in sys.path:
51
sys.path.append(handlerpath)
54
return dispatch.handler(req)