X-Git-Url: http://dolda2000.com/gitweb/?a=blobdiff_plain;f=wrw%2Fdispatch.py;h=10cc2f6ef8014d451e330ebdf9119eee00bf3627;hb=10ba659d32518d2d09b12ada86a380798b378fe7;hp=709cfe4e18dedad2921de5e7390e4a601c313f29;hpb=f593b3dbae242213fa6ea3e1b11310fe15d6ddad;p=wrw.git diff --git a/wrw/dispatch.py b/wrw/dispatch.py index 709cfe4..10cc2f6 100644 --- a/wrw/dispatch.py +++ b/wrw/dispatch.py @@ -1,3 +1,6 @@ +import sys, traceback +from . import env, req, proto + __all__ = ["restart"] class restart(Exception): @@ -39,7 +42,20 @@ class iterproxy(object): if hasattr(self.bk, "close"): self.bk.close() +def defaulterror(req, excinfo): + from . import resp + traceback.print_exception(*excinfo) + raise resp.httperror(500) + +def wraphandler(handler, excinfo): + def wrapped(req): + return handler(req, excinfo) + return wrapped + +errorhandler = env.var(defaulterror) + def handle(req, startreq, handler): + eh = errorhandler.val try: resp = [""] while True: @@ -48,7 +64,18 @@ def handle(req, startreq, handler): break except restart as i: handler = i.handle + except Exception as i: + if eh is None: + raise + handler = wraphandler(eh, sys.exc_info()) + eh = None req.commit(startreq) return resp finally: req.cleanup() + +def handleenv(env, startreq, handler): + if not "HTTP_HOST" in env: + return proto.simpleerror(env, startreq, 400, "Bad Request", "Request must include Host header.") + r = req.origrequest(env) + return handle(r, startreq, handler)