2 # Apache mod_python interface
4 # Aaron Klingaman <alk@absarokasoft.com>
5 # Mark Huang <mlhuang@cs.princeton.edu>
7 # Copyright (C) 2004-2006 The Trustees of Princeton University
8 # $Id: ModPython.py,v 1.4 2007/01/11 22:05:15 mlhuang Exp $
14 from mod_python import apache
16 from PLC.Debug import log
18 from PLC.API import PLCAPI
23 if req.method != "POST":
24 req.content_type = "text/html"
25 req.send_http_header()
28 <title>PLCAPI XML-RPC/SOAP Interface</title>
30 <h1>PLCAPI XML-RPC/SOAP Interface</h1>
31 <p>Please use XML-RPC or SOAP to access the PLCAPI.</p>
37 request = req.read(int(req.headers_in['content-length']))
39 # mod_python < 3.2: The IP address portion of remote_addr is
40 # incorrect (always 0.0.0.0) when IPv6 is enabled.
41 # http://issues.apache.org/jira/browse/MODPYTHON-64?page=all
42 (remote_ip, remote_port) = req.connection.remote_addr
43 remote_addr = (req.connection.remote_ip, remote_port)
46 response = api.handle(remote_addr, request)
48 # Shut down database connection, otherwise up to MaxClients DB
49 # connections will remain open.
53 req.content_type = "text/xml; charset=" + api.encoding
54 req.send_http_header()
59 except Exception, err:
60 # Log error in /var/log/httpd/(ssl_)?error_log
61 print >> log, err, traceback.format_exc()
62 return apache.HTTP_INTERNAL_SERVER_ERROR